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The invention is described in the following statement:- 
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The present inventions relate to a self mapping surface and other related applications 
as described herein. 

The inventions have been developed primarily for use with a printer which interacts 
with the Internet or World Wide Web and will be described hereinafter predominantly with 
5 reference to that application. However, the inventions are not limited to that particular 
field of use. 

While the following detailed description is of specific embodiments of the 
inventions, it will be appreciated by those skilled in the art that these inventions may be 
embodied in many other respective forms. Such forms include the numerous novel 
1 0 features, novel interactions and novel combinations of features and interactions that are 
described in the accompanying Appendices. 

The specific embodiments of the inventions are disclosed in the accompanying 
documents that are respectively identified as: 

Appendix 1, Netpage, System Overview, draft version 0.3; 
1 5 Appendix 2, Netpage, Applications, draft version 0. 1 ; 

Appendix 3, Netpage Printer, Design Description, draft version 0.3; and 
Appendix 4, S-print Product Concept, draft version, 0.2. 
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1 Introduction 



Netpages are pages of high-quality text, graphics and images printed on ordinary 
paper, but which work almost like interactive Web pages. Information encoded m 

T^IH 1 IT 1S , PiCkCd UP by m °l««caUy-i»aging pen and transmitted 

to the network. Act.ve "links" and "buttons" on each page can be "pressed" with 
Je pen to request information from the network or signal preferences to a server 
Text written by hand on a Netpage is automatically recognized via the pen ' 
a^ing forms to be filled in. Signatures recorded on a Netpage are automari-' 
cany verified, allowing e-commerce transactions to be securely authorized. 

The pen, shown on the right, works in conjunction with a Netpage Printer an 
Internet-connected printing appliance for home, office or mobile use The 
pen is wireless and communicates with the Netpage Printer using an 
encrypted radio frequency signal. 

The Netpage Printer delivers, periodically or on demand, personalized newspapers, maga- 

NeS^ ,?r, hUreS ° ther P ublications > 311 P^ted at high quality as interactfve 
Netpages. Unlike a personal computer, the Netpage Printer, shown on the right is m 
appliance typically wall-mounted in the kitchen or near the breakfast table, i e the place 
where the morning news is first consumed, and the household's point of departure for the 
day. It also comes in tabletop, desktop, portable and miniature versions. 

Netpages printed at their point of consumption combine the ease-of-use 
or paper with the timeliness and interactivity of an interactive medium. 

Netpages are crucially enabled by Memjet printing technology [11 
which, makes high-speed magazine-quality printing affordable to con- 
sumers. A Netpage publication has the physical characteristics of a tradi- 
tional newsmagazine, i.e. a set of letter-size glossy pages printed in full 
color on both sides, bound together for easy navigation and comfortable 
handling. The Netpage Printer prints 60 to 90 full-color Netpages per 
minute. r & K 

The Netpage Printer exploits the growing availability of broadband Inter- 
net access. Cable service is available to 95% of households in the United 
Mates [56], and cable modem service offering broadband Internet access 
is already available to 20% of these [8]. The Netpage Printer also oper- 
ates with slower connections, but with longer delivery times and lower 
image quality. 

Netpage Publication Servers on the Internet deliver print-quality publica- 
tions to Netpage Printers. Periodical publications are delivered automati- 
cally to subscribing Netpage Printers via pointcasting and multicasting 
Internet protocols. Personalized publications are filtered and formatted 
according to individual user profiles. 

N^2lt^ nt V U l P T nUmber ° f P™ 8 ' a P 6 " Can W0 * with a "y number of 
Netpage Printers Each Netpage Pen has a unique identifier. A household may have a col- 
lection of colored Netpage Pens, one assigned to each member of the family This allows 
each user to maintain a distinct profile with respect to a Netpage Publication Server. A 
Netpage Pen can also be registered with a Netpage Registration Server and linked to one 
or more payment card accounts. This allows e-commerce payments to be securely autho- 
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rized using the Netpage Pen. The Netpage Registration Server compares the signature cap- 
tured by the Netpage Pen with a previously registered signature, allowing it to authenticate 
the user's identity to the e-commerce system. Other biometrics can also be used to verify 
identity. A version of the Netpage Pen includes fingerprint scanning, verified in a similar 
way by the Netpage Registration Server. 

Although a Netpage Printer delivers periodicals such as the morning newspaper without 
user intervention, it never delivers unsolicited junk mail. It only delivers periodicals from 
subscribed or otherwise authorized sources. The Netpage Printer is unlike a fax machine 
or e-mail account which is visible to any junk mailer who knows the telephone number or 
email address. 



There are a number of advantages to publishing to Netpage Printers. The magazine quality 
of Netpage Printer output makes it a more attractive publishing and advertising medium 
than both traditional newsprint and computer screens. 

The cost of paper and ink consumption is transferred to the user. Subscription fees can be 
eliminated entirely in lieu of the user taking on this extra cost, and the user thus perceives 
a better-value product. The erratic price of newsprint is removed from publishers' profit 
equations, resulting in more stable margins. A new market for paper and ink consumables, 
with its own margins, is created. 

The cost of consumables can be selectively subsidized, for example when non-editorial 
publications such as product brochures and account statements are printed. 

Capital and maintenance expenditure on printing plant is effectively transferred to the 
user, although the perceived expense is small because Netpage Printers are sold at close to 
cost or given away to encourage adoption, subsidized by future advertising profits. Main- 
tenance can also be subsidized or its cost included in a longer term service agreement. 

Costly physical distribution is replaced by electronic distribution via a preexisting and 
widely subscribed network - the Internet. 

Both the editorial and advertising content of publications delivered via the Netpage Net- 
work can be customized for each user. Editorial content can be personalized according to 
the user's profile. Advertising can be localized to the user's locality and optionally tar- 
geted to the user's demographic. 

A personalized publication can be a small fraction of the size of its traditionally-delivered 
counterpart, yet contain the same amount of information relevant to the user, and in a more 
accessible form. The user appreciates the more efficient and digestible publication. 

Localized advertising can be targeted to more specific localities and their associated 
demographics, and this allows advertising space to be exploited more efficiently, i.e. with 
less waste. Advertisers are constantly pressing traditional publishers for greater localiza- 
tion, something which they have great difficulty delivering cost-effectively. 

By revealing personal information such as age, gender, marital status, income, profession, 
education, etc., the user can allow the advertising to be more carefully targeted. In return 
they can receive greater subsidies and discounted product offers. As advertising becomes 
more targeted, it becomes less of a nuisance and more of a service in itself. 
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Although the publication's per-page circulation figures fall drastically, the publication's 
actual per-section readership is preserved, and the correspondingly higher advertising 
rates for personalized delivery can exactly compensate for this. 

Advertising delivered via the Netpage Network has the dual benefits of print and online 
delivery. Print supports the impact of large-format ads. Online delivery supports customi- 
zation, linking, and measurability, and consequently online charging models. 

Consider a full-page advertisement for a new car model in a newsmagazine delivered via 
the Netpage Network. The advertising campaign can be national or even international 
The ad only appears if compatible with the user's demographic, either implied by their 
ZIP Code or more explicitly by their personal details. Anyone who requests a product bro- 
chure via the on-ad button receives one immediately via their Netpage Printer, customized 
with a list of local dealers. If they press a particular -aier's "contact me" button in the 
brochure, the dealer receives a message via the system and contacts the user by telephone. 

The publisher profits in the normal way by selling the advertising space, but can also 
profit by receiving a fee on the "click-through" to the brochure, and a commission on any 
product sale which eventuates. 

The Netpage Network promises to be the most effective advertising medium ever con- 
ceived. It combines the editorial and print quality of traditional publications with arbi- 
trarily finely targeted advertising, and provides a direct link between advertising, product 
information, and purchasing. Added revenue from click-through fees and e-commerce 
commissions may even allow users' costs - printer, ink, paper, and Internet access - to be 
fully subsidized. 
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2 The Demise of Paper 

Online publication has many advantages over traditional paper-based publication From 
the consumer's point of view, information is available on demand, information can be nav- 
igated via hypertext links, information can be searched, and information can be automati- 
. cally personalized. 

From the publisher's point of view, the costs of printing and physical distribution are elim- 
inated, and the publication becomes more attractive to the advertisers who pay for it 
because it can be targeted to specific demographics and linked to product srtes. 

Online publication also has a few disadvantages. Computer screens are inferior to paper. 
At the same quality as a magazine page, an SVGA computer screen displays only about a 
fifth as much information 1 . Both CRTs and LCDs have brightness and contrast problems, 
particularly when ambient light is strong. Ink on paper, being reflective rather than emis- 
sive, is both bright and sharp in ambient light. 

Faced with reading more than the most trivial amounts of text on a screen, most people 
nrefer to print it before reading it. Increasingly, online publishers are recognizing this and 
providing information in formats suitable for printing. At one extreme this means provid- 
ing text-only versions of documents so they print efficiently, i.e. without imposing a 
screen format on the printed page; at the other extreme it means providing formatted ver- 
sions of documents - e.g. in Adobe's Portable Document Format (PDF) - so they print at 
high quality. 

Editorial content is often compromised to fit the online medium and the habits of the peo- 
nle who frequent it, who tend to browse rather than read. Although powerful new advertis- 
ing models become possible, it becomes more difficult to deliver effective advert.sements. 

To truly enable online publication, many people envisage a universal information appli- 
ance - a lightweight portable "tablet" with a page-size touch-sensitive color display and a 
Ih-bandwidth wireLs connection to the Internet. First proposed by Xerox PARC's Alan 
Kay in the mid 1970s in the form of the "Dynabook", and partially realized m recent 
paperback-sized electronic books, even Bill Gates is now confidently predicting that such 
a device will soon augur the death of paper publications [24]. 

To achieve low power consumption, low weight, and paper-like display quality, a bistable 
reflective display technology is required. Several ^"^.^^ ^^^S. 
labs, including Kent Display's cholestenc LCD technology (chLCD) [35], Xerox Gyr 
con" rotating ball technology [27], and E Ink's electrophoretic technology [20,46]. 
ChLCD is arguably closest to practical deployment [19]. 

Next-generation cellular phone networks promise 2Mbps packet switch ing ^ U. cornpara- 
ble to the broadband access people are getting used to in cable networks [43]. Satellite net- 
works while offering or promising still higher speeds [28,49,62], require receivers 
difficult to deploy in mobile devices. 

Beyond the vision of the basic tablet, E Ink imagines its digital ink "printed" onto a num- 
ber of flexible pages bound into a book, preserving the physical navigab.lity of a 
paper-based publication, and approaching its low cost, but allowing the pages to be rewr.t- 

I. Assuming a magazine page has'an equivalent digital resolution of 200 continuous-tone pixels per inch. 
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ten electronically in place. They optimistically predict newspapers delivered in this way 
within rive years [15], despite fundamental problems yet to be overcome [19]. 

The advantages of a tablet are many. Unlike a desktop or notebook computer, a tablet may 
actually provide a pleasant reading experience. Unlike a paper publication, a tablet pro- 
vides intelligent access to an unlimited amount of information; its weight is not dictated 
by the amount of information it carries. More than just an information appliance, it can 
also act as a multi-purpose multimedia communications device and interactive entertain- 
ment device. 

A tablet has disadvantages too. It uses batteries which run down and have to be recharged 
It may break when dropped or malfunction when exposed to hot coffee. It's not quite 
cheap enough to be disposable - so there's still a problem if it's misplaced or stolen It has 
a "user interface" which has to be learned. The leading candidate display technology - 
chLCD - is still less than half as reflective (i.e. "bright") as paper. 

The drawbacks of traditional paper-based publications have little to do with paper itself 
and much to do with how the information gets onto the printed page. The economics of 
centralized printing and distribution prevent the kind of information selection, personal- 
ization and navigation people have come to expect from interactive electronic media such 
as the Internet. The inefficiency of printing and distributing a hundred-page newspaper to 
a customer who may read only a few pages is widely decried. 

Given a technology such as Memjet, it becomes economic to print high-quality publica- 
tions at their point of consumption rather than at their point of production The Netpage 
Printer leverages Memjet to deliver personalized publications to the home, gaining many 
of the advantages of online publication, while retaining the ease-of-use of high-quality 
printed ink on paper. 

Netpages and the Netpage Printer address the key problems of online publication, without 
relying on the development and consumer acceptance of a new reading device. 
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3 News and Advertising Trends 



3.1 Newspapers 

Pe.p,e obtain news from . variety ™ 

tave i time to ™d - fcvor television 
ovTrS* [16]. Yet six out often adult Americans read a newspaper every day [52]. 

tion of about 10 million. 

In 1997 newspaper companies' revenue exceeded $24 billion, a five-year high and mar- 
gVs nudgS [38], due both to increased spending on adverting and to reduced 
prices of newsprint. 



newspapers. 



to use and mofe entertaining than ever before, if at the expense of some hard news. 

operate more as news aggregators than news gatherers. 
Advertising typically contributes more 

ToS^ 
40% [51]. 

Advertisers are pursuing increasing* specific 

ership over raw circulation [23], and using more targeted media where P^ lb *^fJ 
Ses for example, have more specific readerships than newspapers, free shoppers are 
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3.2 Online News Deuvery 



exhau«ed»Mm J ^ ^ SeCt '° n after another until the presentation [isl 

exhausted [10]. Interestingly, a majority of traditional newspaper readers admit thevUln 

a. un.me hypertext, by contrast, .s both a limitless resource and a bottomless pit. 
While traditional news publishers such as The New York Times can denlov fi.H • i 

ries IE mo e ters 46"/ Ta ^P 6 "'" 8 Ma j° r ° r breakin 8 «™s 

when^rLT '" f Amencans say they only follow national news stories 

when something major is happening" [22]. stones 

we^rnl 0 L1o m e C r ""T ' nten,et P ° PU ' ati ° n haS become mainstream, and the 
weather has become the most popular news online. This is closely followed by technology^ 
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news, entertainment news, and local news. As one observer puts it, all of this "sound[s] 
like the 6 o'clock news" [53]. As a reflection of these habits, the online audience share of 
national newspapers has diminished from 23% in 1995 to 16% in 1998, while the online 
audience share of broadcast TV sites has grown. 



At its simplest, advertising alerts a motivated customer to the availability of a product, 
possibly at a competitive price. At a more sophisticated level, advertising seeks to influ- 
ence future purchasing decisions by creating brand awareness. Ultimately, advertising 
seeks to create desire for a product even when actual need is absent. 

Advertising prices are traditionally based on how many people see the advertisement, and 
their spending power in relation to the product. Tn practice, the more homogeneous the 
demographics of the audience, the easier it is to match to a product, and hence the higher 
the corresponding advertising cost per thousand (CPM). Broadcast media use ratings and 
timeslot demographics to set advertising rates. Print media use audited circulation figures 
and sectional readership demographics. 

The simplest online advertising model is also based on how many people see the ad. 
Online this has the advantage of being based on solid numbers, since the number of 
"impressions" of a particular Web page can be counted exactly. 

The specific advantage of an online ad, however, is that the ad itself can measurably cap- 
ture a sales lead by acting as a link to a product site. The product site may simply provide 
more product information in the form of specifications, pricing, and ordering details. It 
may also support immediate online ordering, thus completing the link from ad to sale. 
Beyond providing simple ad exposure, it is this measurable linking of advertisement to 
sales lead or sale which is the strength of online advertising [54]. Cost per click (CLC) 
charging is gaining acceptance but is still controversial. 

Beyond CLC, there exists the possibility of paying a commission to the ad host on any sale 
that actually eventuates [57]. Amazon.com is probably the best-known example of a com- 
pany paying commissions to other sites in this way. 

The broader advantage of online advertising is that advertising can be localized and tar- 
geted arbitrarily finely, in conjunction with the publication of online content such as news. 
This is the strategy pursued by online advertising. agencies such as Click-Through [14], 
which acts as the middle-man between advertisers and online content publishers. They 
expect online advertising to represent more than 10 percent of all advertising revenue by 



Since online ads are necessarily small-format, they communicate best with motivated cus- 
tomers already on the look-out for a particular product or service. Online ads are less 
suited to building brand awareness or creating buying desires, since the real substance of 
the advertisement - the product Web site - is a click away from the initial small-format ad. 
A small-format online ad can't provide the single-hit emotional impact of a large-format 
print ad, and conversely, the online world can't support the large-format ads that print can. 

So-called interstitial ads, which appear full-screen when traversing from one page of 
information to the next, go some way to providing a medium for larger-format ads online 
[57]. User resistance, however, seems to be preventing their widespread use. 



3.3 



Online Advertising 



2001. 
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3.4 Onune Classified Advertising 

Classified advertising is indisputably suited to online delivery. Unlike their traditional 
printed counterparts, online classifieds can be easily searched, and are not subject to space 
constraints. The online migration of classified advertising is considered a serious threat to 
newspapers' classified advertising profits [59], and some newspapers are building an 
online presence for this reason alone. Some observers predict as much as 50% of classified 
advertising revenue moving online within the next ten years [71]. 

Another problem faced by newspapers, who rely on classifieds for up to 40% of advertis- 
ing spending, is that many newcomers are offering free online classified advertising as a 
way of building a venue for non- classified advertising. 
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4 News Personalization 

From the reader's point of view, a personalized news publication can provide more infor- 
mation in fewer pages. The actual form this personalization takes, however, is not neces- 
sarily obvious. 

The MIT Media Lab's News in the Future (NiF) project has been championing the concept 
of "The Daily Me" for almost two decades [44]. Nicholas Negroponte, one of the project's 
founders, envisages a highly personalized news publication which is no longer driven by 
'"what other people think is news" [48]. By way of examples close to his own needs, it 
includes news about people and places about to be encountered, and puts t4 the most impor- 
tant [news] of all" - a summary of e-mail - on the front page [6]. Negroponte recognizes 
the need to vary the degree of personalization, advocating a higher "serendipity factor" on 
a lazy Sunday than on a working weekday. 

The opposing view holds that the value of a news publication lies precisely in its shared 
nature. It reflects the common concerns and values of a community of readers, and estab- 
lishes a baseline of expectations of what they are all supposed to know [66]. As a conse- 
quence, the publication also speaks with a consistent editorial voice and with consistent 
assumptions about the reader's level of background knowledge. Such a shared publication 
allows its readers to orient themselves in relation to their community. 

NiF's Walter Bender answers the charge (in his own words) of "The Daily Me engender- 
ing a fragmented world populated by self-interested myopes", by stressing the possibilities 
of personalizing individual news items [5]. This can consist in varying the depth of an 
item, or supplementing it with background information, based on the reader's level of 
knowledge. It can involve interpreting information relative to the reader's background, 
such as (somewhat dubiously) making value judgements about the weather relative to the 
reader's normal home town weather. It can also be as simple as using metric rather than 
imperial units. 

Fish Wrap [10,45], MIT's personalized campus newspaper and NiF's latest offering, goes 
further by creating a front page whose content represents an explicit community consen- 
sus. Each front page news item is prioritized according to the number of readers who put it 
forward for inclusion. The rest of the newspaper is still personalized according to each 
reader's profile, consisting of reader-defined sections containing topics of interest. 

There are two implications of recognizing the shared nature of news. Firstly, some news is 
news to everybody in a community, no matter how personalized they claim they would 
like their news to be. This implies that the community must make decisions about news 
item priority, either directly (as in Fish Wrap) or indirectly via a proxy (i.e. an editor). 

Secondly, a news item can only be properly understood in the context of the community 
for which it is intended. This implies that a news item must be branded with its source 
(assuming that the source implies the intended target). As an example, it is significant 
whether a news item regarding the proof of Fermat's last theorem is branded with New 
Scientist or The New York Times. To a professional mathematician, the latter implies, by 
its very existence, that the proof is of significance beyond the scientific community. 

Of course, a news item must also be branded to allow its source to build and maintain its 
brand. The brand then allows the reader to infer the quality of the news item from the 
known quality of the source. 
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Most personalization of news uses feature-based filtering. This means that news item con- 
tent is matched to topics and keywords in the reader's profile. News sources tag the items 
they produce with various information to allow them to be effectively filtered. This tag- 
ging may be brief or extensive, and may include such things as news item urgency, byline 
n e -F c-t-^rv sub j e ct(s), keyword(s), date and time, and location [32]. The body text of a 
news item can also be scanned directly for keywords, but this may result in false matches 
if keywords are interpreted out of context. Items in the text such as personal names and 
locations can be tagged to reduce such ambiguity [32]. Similarly, dates, times, and mone- 
tary amounts can be tagged to allow localized presentation. 

Feature-based filtering suffers from a number of problems. Filtering based on tags is only 
as good as the original tagging. The latest tagging standards are only just beginning to be 
adopted [7]. Filtering based on the text itself is constrained by the intelligence of the text 
parsing. If based simply on keyword matching, it can be both inaccurate, generating false 
matches because of word sense ambiguity, and imprecise, generating false mismatches 
because of a lack of inference. 

Feature-based filtering is incapable of discerning more abstract attributes such as quality, 
style, and point-of-view (unless they're indicated by tags). And since it only matches 
items anticipated by the user's profile, it is a poor generator of serendipitous finds. 

Fish Wrap's front page comes into existence based on a crude form of collaborative filter- 
ing. In its broader form, collaborative filtering involves sharing recommendations (or rat- 
ings) among like-minded people [55]. This means that one person's ratings influence 
another person if and only if the two share similar interests, i.e. they have similar rating 
histories. Collaborative filtering overcomes many of the problems of feature-based filter- 
ing, since ratings originate with people who have digested the items in question, rather 
than from automated analysis of the items. Collaborative filtering sidesteps the issue of 
explaining why a person might like a particular item. 

Collaborative filtering has problems of its own. The system only works if people are will- 
ing to contribute ratings. In contributing ratings, of course, they are both doing the com- 
munity a service and tuning their own interest profiles. The statistical error in correlating 
people's interests decreases as the number of ratings increases. However, incentives may 
have to be offered to encourage people to contribute ratings. 

To bootstrap the accumulation of ratings for new items, an independent mechanism must 
exist to distribute them to a critical mass of people. Conversely, to bootstrap the accumula- 
tion of interest profiles for new users, an independent mechanism must exist to distribute a 
critical mass of items to them. 

To allow meaningful accumulation of ratings, a sufficient period of time must be allowed 
to elapse. This may conflict with the timely delivery of items in question. 

The statistical correlation between different people's interests, represented by their rating 
histories, is most meaningful when the ratings apply to homogeneous items. For a set of 
heterogeneous items, collaborative filtering is best applied to homogeneous subsets. 

In a news setting, collaborative filtering is best applied to feature articles. Features have 
the longer life span required to support the accumulation of ratings, and are often appreci- 
ated for abstract qualities best singled out by collaborative filtering (good writing, humor, 
incisiveness, etc.). 
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Naturally, the larger a publication's readership, and the better its taste in relation to a 
potential reader, the stronger the publication's brand will appear to that reader. 

Although it's easy to become preoccupied with automatic filtering, in reality there's more 
to editing the news than just filtering news feeds. An editor also solicits news, commis- 
sions analysis, and offers opinion, ideally ensuring that the publication offers a balanced 
and complete view of the world. 

Perhaps the most important personalization step a reader takes is in selecting a particular 
publication from a set of available publications, based on its perceived quality and rele- 
vance. 

Thus the publication's brand equates to the highest-level and most useful filter of all. 
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5 Netpage System Architecture 



The Internet is a worldwide collection of interconnected networks which communicate 
using the TCP/IP protocol suite [58]. A TCPAP-based internetwork not connected to the 
Internet is often referred to as an internet (i.e. with a lower-case M*). When an internet is 
deployed within an organization, it is often termed an intranet. 

Access to the Internet is widespread in developed countries. In the United States, for 
example, 41% of the population has access to the Internet [53]. 

While most consumers still access the Internet via low-speed dial-up modems connected 
to the switched telephone system, inexpensive broadband access is becoming available to 
a growing number of households via the cable networks. Cable service is available to 95% 
of American households [56], and cable modem service is available to a 20% subset [8]. 
While dial-up modems offer speeds of up to 56Kbps, cable modems offer practical speeds 
of up to about 3Mbps 1 , i.e. over 50 times faster. 

DSL (Digital Subscriber Line) [1 1,12], while offering similar speeds to cable modems but 
via the telephone system, is not yet widely used. ISDN (Integrated Services Digital Net- 
work), although widely used for corporate access, has had little consumer impact due to its 
high price and comparatively low performance. 

The deployment of third-generation (3G) cellular telephony within the next few years will 
bring practical mobile broadband speeds of 2Mbps [21]. 3G cellular uses WCDMA (wide- 
band code-division multiple access), a spread-spectrum technology. Satellite systems are 
arguably closer to offering even faster broadband Internet access [28,49,62]. 

The core of the Internet is made up of a number of independent high-speed fiber-optic net- 
works connected into NAPs (Network Access Points) or peered directly. These have until 
recently used single- wavelength TDM (Time-Division Multiplexing) SONET (Synchro- 
nous Optical Network) transmission systems which utilize about 1% of an optic fiber's 
capacity to yield a 2.5Gbps OC-48 channel 2 . Carriers are now beginning to deploy 
multi-wavelength DWDM (Dense Wavelength-Division Multiplexing) systems which 
yield up to 40 such channels per optic fiber, thus increasing network capacity significantly 
without requiring the laying of more fiber [9,39]. Internet architects are therefore now 
contemplating aggregate capacity in the terabit (Tbps) range. 

The Internet uses the four-layer TCP/IP protocol suite. The application layer provides var- 
ious end-to-end application services, and is a client of the transport layer which provides 
end-to-end delivery services. The transport layer in turn is a client of the network layer 
which provides packet routing. The network layer is a client of the link layer which encap- 
sulates specifics of the protocols and hardware of the actual communications links. 

The core Internet transport protocol, TCP (Transmission Control Protocol), provides a 
reliable end-to-end delivery service. The core Internet network protocol, IP (Internet Pro- 
tocol), provides an unreliable and connectionless packet routing service. IP may lose or 



1. Although the cable supports 30Mbps and the cable modem theoretically supports 10Mbps. 

2. SONETchannels have an OC-n designation, where OC stands for Optical Carrier, and n gives the channel speed in 
units of about 52Mbps. An OC-48 channel therefore has a speed of about 2.5Gbps. 
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deliberately discard packets, and may deliver packets out of order, and it is the responsibil- 
ity of a higher layer to provide a reliable end-to-end service. 

With the proliferation of streaming media services on the Internet, support for multicast is 
spreading rapidly. Multicast is a form of broadcast with a specific set of recipients. It 
makes efficient use of network capacity because a packet traverses a network link once 
rather than once per recipient. It is particularly efficient if the recipients are connected to 
the Internet via an intrinsically broadcast medium such as cable or satellite. The @Home 
cable network has successfully enabled multicasting of streaming media services [37]. 

IP Multicast is an extension of IP, and so is unreliable. While this is often acceptable for 
time-critical data such as streaming video, it may not be acceptable for other shared data 
types. Significant effort is being expended to develop reliable multicast transport proto- 
cols on top of IP Multicast. Although several reliable multicast protocols are available and 
have been deployed [40,41,29,30], the Internet standardization process is incomplete [31] 



5.2 Netpages and Netpage Documents 

Netpages are the foundation on which a Netpage Network is built. They provide a 
paper-based user interface to published information and interactive services. 
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Figure 1. Netpage Document structure (* indicates an n-ary relationship) 
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Each Netpage consists of a compact page layout maintained persistently by a Netpage 
Page Server. The page layout refers to objects such as images, fonts and pieces of text, 
typically stored elsewhere on the Netpage Network. 

Netpages are organized into Netpage Documents. Both Netpages and Netpage Documents 
are assigned globally unique identifiers. 

Each Netpage Document has a set of document instances, each of which describes a 
printed instance of the document. Each Netpage in the Netpage Document has a corre- 
sponding set of page instances, each of which describes a printed instance of the page. 
Both page instances and document instances are assigned globally unique identifiers. 
They are also uniquely associated with the printer on which they are printed and the user 
who initiated the print request, if known. 

Each page instance maintains a set of user-supplied values for fields in the page layout. 
This ensures that user input is captured and stored independently for each page instance. 
The separation of page instances and Netpages is crucial for pages which contain input 
fields, i.e. forms. It is not crucial for pages devoid of input fields, but still useful because it 
supports independent auditing of each page instance. 

The physical page image includes encoded information which identifies the page instance 
and hence the Netpage to which it corresponds. It also includes encoded information 
which superimposes an addressable spatial grid over the page image, to allow pen actions 
performed relative to the page image to be correlated with the contents of the page layout. 

The encoded information is normally printed in infrared-absorptive ink on any normal 
paper substrate which is infrared-reflective. Near- infrared wavelengths are invisible to the 
human eye but are easily sensed by a solid-state image sensor with an appropriate filter. 

The encoded information is picked up by an infrared-imaging pen and transmitted to the 
associated Netpage Printer. The pen is wireless and communicates with the Netpage 
Printer using an encrypted radio frequency signal. 

The encoded information is organized as a set of tags, each containing both the id of the 
page instance and the position of the tag. The tags tile the entire page image, and are suffi- 
ciently small and densely arranged that the pen can reliably image at least one tag even on 
a single click on the page. It is important that the pen recognize the page instance id and 
position on every interaction with the page, since the interaction is stateless. 

The tags are error-correctably encoded to make them resilient to errors introduced by dirt 
on the page or during the imaging process. 

Memjet-based Netpage Printers are designed to print a tag grid using infrared (IR) ink. 
Printers not enabled for IR printing have the option to print tags using IR-absorptive black 
ink, although this restricts tags to otherwise empty areas of the page. Although such pages 
have more limited functionality than IR-printed pages, they are still classed as Netpages. 



A Netpage Network consists of a distributed set of Netpage Publication Servers, Netpage 
Page Servers, and Netpage Printers connected via an internet. In technological terms this 
document describes any Netpage Network. In business terms it usually refers to the 
Netpage Network connected via the Internet. 
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As described above, a Netpage Page Server maintains persistent information about 
Netpage Documents, Netpages, and their printed instances, to allow pen operations on 
printed pages to be interpreted intelligently. 

The Netpage Network includes any number of Netpage Page Servers, each handling a sub- 
set of Netpages. As described above, each page instance is identified by a globally unique 
id which ,s encoded in the tag grid of the corresponding printed page. The Netpage Printer 
uses this id to retrieve the page layout of the page from a Netpage Page Server when it 
needs to interpret pen operations relative to the page. 

The Netpage Printer uses the internet Distributed Name System (DNS) to resolve a 
Netpage instance id into a page instance maintained by a particular Netpage Page Server. 

The DNS is a protocol and a hierarchical system of name servers used to resolve internet 
domain names into resources. Planned enhancements to the DNS allow it to be used to 
resolve more general Uniform Resource Identifiers (URls), and in particular Uniform 
Resource Names (URNs), into resource locations [18]. Netpage instance ids are formu- 
ated as URNs allowing the enhanced DNS to be used to resolve them. In the absence of 
timely standardization and deployment of an enhanced DNS on the Internet, the Netpage 
Network can deploy its own system of enhanced name servers. 

A Netpage Publication Server is an internet server which publishes Netpage Documents to 
Netpage Printers. It is described in Section 6. 



5.4 The Netpage Printer 



The Netpage Printer is the appliance which prints Netpage Documents. It is connected to a 
Netpage Network via an internet, ideally via a broadband connection. 

Apart from identity and security settings in non-volatile memory, the Netpage Printer con- 
tains no persistent storage. As far as a user is concerned, the network is the computer [60] 
Netpages function interactively across space and time with the help of the distributed 
Netpage Page Servers, independently of particular Netpage Printers. 

The Netpage Printer receives Netpage Documents from Netpage Publication Servers 
Each document is distributed in two parts: the page layouts, and the actual text and image 
objects wh,ch populate the pages. Because of personalization, page layouts are typically 
specific to a particular subscriber and so are pointcast to the subscriber's printer. Text and 
■mage objects on the other hand, are typically shared with other subscribers, and so are 
multicast to all subscribers' printers. 

The Netpage Publication Server optimizes the segmentation of document content into 
pointcasts and multicasts. After receiving the pointcast of a document's page layouts the 
printer knows which multicasts, if any, to listen to. 

Once the printer has received the entire document's page descriptions, i.e. page layouts 
and objects, it can print the document. 

The printer rasterizes and prints odd and even pages simultaneously on both sides of the 
sheet. It therefore contains duplexed print engines and imaging units. 

The printing process consists of two decoupled stages: rasterization of page descriptions 
and expans.on and printing of page images. The raster image processor (RIP) consists of 
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one or more standard DSPs running in parallel. The duplexed print engines consist of cus- 
tom processors which expand, dither and print page images in real time, synchronized 
with the operation of the printheads in the imaging units. 

There are four major design variations embodied in the various Netpage Printer models: 

• form factor, pocket, portable, desktop, wall-mount or tabletop 

• printhead width: 4" (photo), VA" (portrait Letter) or 1 1" (landscape Letter) 

• paper source: cut sheet or print cartridge 

• Internet connection: wired or wireless 

The form factor variations yield five basic models, each with variants determined by print- 
head width (and hence printing speed), and paper source. Eight planned models are 
defined in Table 1 , and illustrated in Figure 2. 



Table 1. Netpage Printer models 
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The Deskprinter, Wallprinter and Tableprinter models can be factory-configured with var- 
ious network modules, allowing both wired and wireless versions. The Microprinter and 
Travelprinter both use a cellular telephone module, with the promise of broadband speed 
within a few years. 

The Wallprinter models are ideal for unobtrusive installation in a home, while the Table- 
printer models might be preferred in an office environment. Note that the Tableprinter 
models are Wallprinter models factory-adapted for tabletop use via a stand. The 
Deskprinter, with its small footprint, is ideal for both home and office use. 

The Microprinter prints normal Netpages at quarter size, and provides full wireless 
Netpage Network access in a pocket device. 

The paper roll cartridge contains both paper and ink. The paper is in the form of a contin- 
uous roil, cut on demand by the printer. The 11" print cartridge has a capacity of 1000 Let- 
ter sheets. It also contains the glue supply for binding the sheets of a document together. 
The 8'/2 M print cartridge has a capacity of 50 Letter sheets, or equivaiently 100 A5 sheets. 
The 4" print cartridge has a capacity of 36 6x4 photos, or 41 quarter-size Netpages. The 
8Vi" and 4" print cartridges don't contain a glue supply because neither the Microprinter 
nor the Travelprinter includes a binding mechanism. 

The 4" printhead models print at 30 quarter-size pages per minute. The 814" printhead 
models print at 60 pages per minute, or 30 duplex sheets per minute. The 11" printhead 
models print at 90 pages per minute, or 45 duplex sheets per minute. 
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Figure 2. Netpage Printer family 
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5.5 



The Netpage Pen 



The Netpage Pen operates both as a normal marking ink pen and as a non-marking stylus. 
When either nib is in contact with a Netpage, the pen continuously monitors its move- 
ments relative to the page. The nib is attached to a pressure sensor. The pen pressure can 
be interpreted relative to a threshold to indicate whether the pen is "up" or "down". It can 
also be interpreted as a continuous value, for example when the pen is capturing a signa- 
ture, to allow the full dynamics of the signature to be verified. 

The pen determines the position of its nib on the Netpage by imaging, in the infrared spec- 
trum, an area of the page in the vicinity of the nib. It decodes the nearest page id and posi- 
tion tag, and adjusts the position given by the tag to account for the distance between the 
area imaged and the actual nib, and the position of the tag in the imaged area. Although 
the position resolution of the tag may be low, because the tag density on the page is 
inversely proportional to the tag size, the adjusted position resolution is quite high, and 
easily exceeds the minimum 200 dpi resolution required for handwriting recognition [61]. 

Pen actions relative to a Netpage consist of a series of strokes. A stroke consists of a 
sequence of time-stamped pen positions on the page, initiated by a pen-down event and 
completed by the subsequent pen-up event. A stroke is also tagged with the page id of the 
Netpage whenever the page id changes, i.e. just at the start of the stroke under normal cir- 
cumstances. 

The position tags on the Netpage contain various control bits. One of these instructs the 
pen to activate its "active area" LED. Thus a region on the page which corresponds to the 
active area of a button or hyperlink can be encoded to activate this LED, giving the user 
visual feedback that the button or hyperlink is active when the pen passes over it. Another 
control bit instructs the pen to capture continuous pen pressure readings and tag the stroke 
with these readings. Thus a region on the page which corresponds to a signature input area 
can be encoded to capture continuous pen pressure. 

Whenever the pen is within range of a printer with which it can communicate, the pen 
slowly flashes its "online" LED. When the pen fails to decode a stroke relative to the page, 
it momentarily activates its "error 5 * LED. When the pen succeeds in decoding a stroke rel- 
ative to the page, it momentarily activates its "ok" LED. 

The pen also contains a pair of passive accelerometers mounted at right angles to each 
other in the plane normal to the pen's axis. The accelerometers respond to gravity and 
allow the pen to compute its tilt. This in turn helps it auto-focus its optics and compute the 
nib-to-tag displacement. If the stroke is being tagged with pen pressure readings^ then it is 
also tagged with tilt readings. 

A sequence of captured strokes, whether tagged with pen pressure and tilt or not, is 
referred to as digital ink. Digital ink forms the basis for the digital exchange of drawings 
and handwriting, for on-line recognition of handwriting [61], and for on-line verification 
of signatures. 

The pen is wireless and transmits digital ink to the Netpage Printer using a radio frequency 
signal. The digital ink data is encrypted for security and packetized for efficient transmis- 
sion, but is always flushed on a pen-up event to ensure timely handling in the printer. 

When the pen is out-of-range of a printer it buffers digital ink in internal memory, which 
has a capacity of more than 12 minutes of continuous handwriting. When the pen is once 
again within range of a printer, it transfers any buffered digital ink. 
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A pen can be registered with any number of printers, but because all state data resides in 
Netpages both on paper and on the network, it is largely immaterial which printer a pen is 
communicating with at any particular time. 



5.6 Netpage Interaction 

When the Netpage Printer receives a digital ink stroke from the pen, it retrieves the page 
layout of the Netpage identified in the stroke, to allow it to correctly interpret the stroke. 
The printer resolves, via the DNS, the address of the Netpage Page Server which holds the 
page layout, and then retrieves the page layout from the server. If the page was recently 
identified in an earlier stroke, then the printer may already have the address of the relevant 
Netpage Page Server in its cache. It may also have the page layout itself in its cache, in 
which case there may be no need to retrieve it. 

Once the printer has the page layout of the Netpage to which the pen stroke refers, it can 
interpret the stroke in relation to the layout and content of the page. This involves hit-test- 
ing the objects on the page to determine which objects the pen is interacting with, in much 
the same way that mouse movements and button presses are interpreted in a graphical user 
interface system. 



A "click" is a stroke where the distance between the pen down position and the subsequent 
pen up position is less than some small maximum. An object which is activated by a click 
requires a click to be activated, i.e. a longer stroke is ignored. The failure of a pen action, 
such as a "sloppy" click, to register is indicated by the lack of response from the pen's 
"ok" LED. 



There are two kinds of interactive objects on a Netpage: hyperlinks and form fields. 

When a hyperlink is activated, the printer sends a request to a handler somewhere on the 
network. The handler is identified by a URI, and the URI is resolved in the normal way via 
the. DNS. There are three types of hyperlinks: general hyperlinks, form hyperlinks, and 
selection hyperlinks. A general hyperlink may implement a request for a linked document, 
or may simply signal a preference to a server. A form hyperlink submits the corresponding 
form to a form handler. A selection hyperlink submits the current selection to a selection 
handler. If the current selection contains a single-word piece of text, for example, the 
selection handler may return a single-page document giving the word's meaning within 
the context in which it appears, or a translation into a different language. Each hyperlink 
type is characterized by what information is submitted to the handler. 

Form fields come in four varieties: checkboxes, text areas, digital ink areas, and signature 
areas. A checkbox accepts a true or false value. Any mark (a tick, a cross, a stroke, a fill 
zigzag, etc.) captured in a checkbox area is assigned as a true value to the corresponding 
field. A text area accepts a text string. Any digital ink captured in a text area is automati- 
cally converted to text via on-line handwriting recognition and the text is assigned to the 
corresponding field. A digital ink area accepts raw digital ink. Any digital ink captured in 
a digital ink area is assigned to the corresponding field. A signature area accepts a hand- 
written signature. Any digital ink captured in a signature area is automatically verified and 
the resulting signature token is assigned to the corresponding signature field. Signature 
verification is discussed in more detail in Section 8. 
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"Editing" commands, such as strike-throughs indicating deletion, are also recognized in 
form fields. 



Table 2. Summary of pen interactions with a Netpage 
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Because the handwriting recognition algorithm works "on-line" (i.e. with access to the 
dynamics of the pen movement), rather than "off-line" (i.e. with access only to a bitmap of 
pen markings), it can recognize run-on discretely-written characters [61] with high accu- 
racy, without a writer-dependent training phase. 



Digital ink, as already stated, consists of a sequence of strokes. Any stroke which starts in 
a particular object's active area is appended to that area's digital ink stream, ready for 
eventual interpretation. Any stroke not appended to an object's digital ink stream is 
appended to the remaining inactive area's digital ink stream. 

Digital ink captured in the inactive area is interpreted as a selection gesture. Any circum- 
scription of one or more objects is interpreted as a selection of the circumscribed objects. 

The printer maintains a current selection for each pen. The selection contains the most 
recent object selected, resolved with reference to the page layout and content. The selec- 
tion can be attached to or pasted into another form, or in general be submitted to a selec- 
tion handler as described earlier. The selection is cleared after an inactivity time-out to 
ensure predictable behavior. 

Table 2 provides a summary of pen interactions with a Netpage. 

5.7 Forms 

As described in Section 5.2, user input on a physical Netpage is ultimately recorded per- 
sistently by a Netpage Page Server together with the corresponding page instance. To 
ensure efficient capture of user input, the printer accumulates input locally. To prevent 
update anomalies, however, the printer temporarily obtains exclusive access to the page 
instance from the Netpage Page Server. The printer flushes input back to the server and 
relinquishes exclusive access when the user initiates a non-local action on the page; after 
an inactivity time-out on the page; when the printer wishes to free up local storage con- 
sumed by the page; and on request from the server. 

When the printer submits a form to a form handler, it simply submits the document 
instance of the form. The form handler retrieves the field values from the Netpage Page 
Server at its leisure. 
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A form can also act as a shared "blackboard" between the user and the form handler, i.e. 
the form handler can query the contents of the form fields maintained by the Netpage Page 
Server without the user explicitly submitting the form. 

For text areas, the raw digital ink is optionally also stored with the page instance on the 
Netpage Page Server. This allows the form handler to interrogate the raw digital ink 
should it suspect the original recognition of the handwriting. This might involve human 
intervention at the application level for forms which fail certain application-specific con- 
sistency checks. As an extension to this, the entire background area of a form can be des- 
ignated as a digital ink area. The form handler can then decide, on the basis of the 
presence of digital ink outside the explicit fields of the form, to route the form to a human 
operator, on the assumption that the user may have indicated amendments to the filled-in 
fields outside of those fields. 

Form fields can optionally be tagged to indicate their meaning. Fields tagged in this way 
may include name and address fields, for example. This semantic tagging allows these 
fields to be automatically filled in whenever a "blank" form is requested by an identifiable 
user, i.e. a user who has registered their identity with the system and linked it to the iden- 
tity of their pen. 

5.8 Standard Features of Netpages 

Each Netpage is printed with the Netpage logo at the bottom to indicate that it is a Netpage 
and therefore has interactive properties. The logo also acts as a "copy" button. In most 
cases pressing the logo produces a copy of the page. In the case of a form the button 
instead elicits a page giving the user the option to print the entire form document. And in 
the case of a secure document, such as a ticket or coupon, the button elicits an explanatory 
note or advertising page. 

The default single-page copy function is handled directly by the relevant Netpage Page 
Server. Special copy functions are handled by linking the logo button to other URIs. 

Once a Netpage form has been submitted, it is marked as submitted by the Netpage Page 
Server and cannot be submitted again. An attempt to do so elicits a status report indicating 
when it was submitted. A copy of the form can still be made, altered, and re-submitted. 

5.9 The Help System 

The Netpage Printer has a single button labelled "help". When pressed it elicits a single 
page of information. This information includes the following: 

• status of printer connection 

• status of printer consumables 

• top-level help menu 

• document function menu 

• top-level Netpage Network directory 

The help menu provides a hierarchical manual on how to use the Netpage System. 
The document function menu includes the following functions: 

• print a copy of a document 
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• print a clean copy of a form 

• print the status of a document 

A document function is initiated by simply pressing the button and then touching any page 
of the document. The status of a document indicates who published it and when, to whom 
it was delivered, and to whom and when it was subsequently submitted as a form. 

The Netpage Network directory allows the user to navigate the hierarchy of publications 
and services on the network. As an alternative, the user can call the Netpage Network 
"900" number "yellow pages" and speak to a human operator. The operator can locate the 
desired document and route it to the user's printer. Depending on the document type, the 
publisher or the user pays the small "yellow pages" service fee. 

The help page is obviously unavailable if the printer is unable to print. In this case the 
"error" light is lit and the user can request remote diagnosis over the network. 
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6 Personalized Publication 
Model 

In the following discussion, news is used as a canonical publication example to illustrate 
personalization mechanisms in the Netpage System. Although news is often used in the 
limited sense of newspaper and newsmagazine news, the intended scope is wider. 

In the Netpage System, the editorial content and the advertising content of a news publica- 
tion are personalized using different mechanisms. The editorial content is personalized 
according to the reader's explicitly stated and implicitly captured interest profile. The 
advertising content is personalized according to the reader's locality and demographic. 

6.1 Editorial Personalization 

A subscriber can draw on two kinds of news sources: those that deliver news publications, 
and those that deliver news streams. While news publications are aggregated and edited by 
the publisher, news streams are aggregated either by a news publisher or by a specialized 
news aggregator. News publications typically correspond to traditional newspapers and 
newsmagazines, while news streams can be many and varied: a "raw" news feed from a 
news service, a cartoon strip, a freelance writer's column, a friend's bulletin board, or the 
reader's own e-mail. 

The Netpage Publication Server supports the publication of edited news publications as 
well as the aggregation of multiple news streams. By handling the aggregation and hence 
the formatting of news streams selected directly by the reader, the server is able to place 
advertising on pages over which it otherwise has no editorial control. 

The subscriber builds a daily newspaper by selecting one or more contributing news pub- 
lications, and creating a personalized version of each. The resulting daily editions are 
printed and bound together into a single newspaper. The various members of a household 
typically express their different interests and tastes by selecting different daily publica- 
tions and then customizing them. 

For each publication, the reader optionally selects specific sections. Some sections appear 
daily, while others appear weekly. The daily sections available from The New York Times 
online, for example, include "Page One Plus", "National", "International", "Opinion", 
"Business", "Arts/Living", "Technology", and "Sports". The set of available sections is 
obviously specific to a publication, as is the default subset. 

The reader extends the daily newspaper by creating custom sections, each one drawing on 
any number of news streams. Custom sections might be created for e-mail and friends' 
announcements ("Personal"), or for monitoring news feeds for specific topics ("Alerts" or 
"Clippings"). 

For each section, the reader optionally specifies its size, either qualitatively (e.g. short, 
medium, or long), or numerically (i.e. as a limit on its number of pages), and the desired 
proportion of advertising, either qualitatively (e.g. high, normal, low, none), or numeri- 
cally (i.e. as a percentage). 

The reader also optionally expresses a preference for a large number of shorter articles or 
a small number of longer articles. Each article is ideally written (or edited) in both short 
and long forms to support this preference. 
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An article may also be written (or edited) in different versions to match the expected 
sophistication of the reader, for example to provide children's and adults' versions. The 
appropriate version is selected according to the reader's age. The reader can specify a 
"reading age" which takes precedence over their biological age. 

The articles which make up each section are selected and prioritized by the editors, and 
each is assigned a useful lifetime. By default they are delivered to all relevant subscribers, 
in priority order, subject to space constraints in the subscribers' editions. 

In sections where it is appropriate, the reader may optionally enable collaborative filter- 
ing. This is then applied to articles which have a sufficiently long lifetime. Each article 
which qualifies for collaborative filtering is printed with rating buttons at the end of the 
article. The buttons can provide an easy choice (e.g. "liked" and "disliked'), making it 
more likely that readers will bother to rate the article. 

Articles with high priorities and short lifetimes are therefore effectively considered essen- 
tial reading by the editors and are delivered to most relevant subscribers. 

The reader optionally specifies a serendipity factor, either qualitatively (e.g. do or don't 
surprise me), or numerically. A high serendipity factor lowers the threshold used for 
matching during collaborative filtering. A high factor makes it more likely that the corre- 
sponding section will be filled to the reader's specified capacity. A different serendipity 
factor can be specified for different days of the week. 

The reader also optionally specifies topics of particular interest within a section, and this 
modifies the priorities assigned by the editors. 

The speed of the reader's Internet connection affects the quality at which images can be 
delivered. The reader optionally specifies a preference for fewer images or smaller images 
or both. If the number or size of images is not reduced, then images may be delivered at 
lower quality (i.e. at lower resolution or with greater compression). 

At a global level, the reader specifies how quantities, dates, times and monetary values are 
localized. This involves specifying whether units are imperial or metric, a local timezone 
and time format, and a local currency, and whether the localization consist of in situ trans- 
lation or annotation. These preferences are derived from the reader's locality by default. 

To reduce reading difficulties caused by poor eyesight, the reader optionally specifies a 
global preference for a larger presentation. Both text and images are scaled accordingly, 
and less information is accommodated on each page. 

The language in which a news publication is published, and its corresponding text encod- 
ing, is a property of the publication and not a preference expressed by the user. However, 
the Netpage Network may provide automatic translation services in various guises. 



The personalization of the editorial content directly affects the advertising content, 
because advertising is typically placed to exploit the editorial context. Travel ads, for 
example, are more likely to appear in a travel section than elsewhere. The value of the edi- 
torial content to an advertiser (and therefore to the publisher) lies in its ability to attract 
large numbers of readers with the right demographics. 



6.2 



Advertising Localization and Targeting 



Confidential 



7 September 1999 



27 



Silverbrook Research Netpage System Overview 



draft v0.3 



Effective advertising is placed on the basis of locality and demographics. Locality deter- 
mines proximity to particular services, retailers etc., and particular interests and concerns 
associated with the local community and environment. Demographics determine general 
interests and preoccupations as well as likely spending patterns. 

A news publisher's most profitable product is advertising "space", a multi-dimensional 
entity determined by the publication's geographic coverage, the size of its readership, its 
readership demographics, and the page area available for advertising. 

In the Netpage System, the Netpage Publication Server computes the approximate 
multi-dimensional size of a publication's saleable advertising space on a per-section basis, 
taking into account the publication's geographic coverage, the section's readership the 
size of each reader's section edition, each reader's advertising proportion, and each 
reader's demographic. 

In comparison with other media, the Netpage System allows the advertising space to be 
defined in greater detail, and allows smaller pieces of it to be sold separately. It therefore 
allows it to be sold at closer to its true value. 

For example, the same advertising "slot" can be sold in varying proportions to several 
advertisers, with individual readers' pages randomly receiving the advertisement of one 
advertiser or another, overall preserving the proportion of space sold to each advertiser. 

The Netpage System allows advertising to be linked directly to detailed product informa- 
tion and online purchasing. It therefore raises the intrinsic value of the advertising space. 

Because personalization and localization are handled automatically by Netpage Publica- 
tion Servers, an advertising aggregator can provide arbitrarily broad coverage of both 
geography and demographics. The subsequent disaggregation is efficient because it is 
automatic. This makes it more cost-effective for publishers to deal with advertising aggre- 
gators than to directly capture advertising. Even though the advertising aggregator is tak- 
ing a proportion of advertising revenue, publishers may find the change profit-neutral 
because of the greater efficiency of aggregation. The advertising aggregator acts as an 
intermediary between advertisers and publishers, and may place the same advertisement in 
multiple publications. 

It is worth noting that ad placement in a Netpage publication can be more complex than ad 
placement in the publication's traditional counterpart, because the publication's advertis- 
ing space is more complex. While ignoring the full complexities of negotiations between 
advertisers, advertising aggregators and publishers, it is clear that the Netpage System 
should ideally provide some automated support for these negotiations, including support 
for automated auctions of advertising space. Automation is particularly desirable for the 
placement of advertisements which generate small amounts of income, i.e. small or highly 
localized advertisements. 

Once placement has been negotiated, the aggregator captures and edits the advertisement 
and records it on a Netpage Ad Server. Correspondingly, the publisher records the ad 
placement on the relevant Netpage Publication Server. When the Netpage Publication 
Server lays out each user's personalized publication, it picks the relevant advertisements 
from the Netpage Ad Server. 
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6.3 



User Profiles 



The personalization of news and other publications relies on an assortment of user-specific 
profile information: 

• publication customization 

• collaborative filtering vectors 

• contact details 

• presentation preferences 

The customization of a publication is typically publication-specific, and so the customiza- 
tion information is maintained by the relevant Netpage Publication Server. 

A collaborative filtering vector consists of the user's ratings of a number of news items. 
As described in Section 4, it is used to correlate different users' interests for the purposes 
of making recommendations. Although there are benefits to maintaining a single collabo- 
rative filtering vector independently of any particular publication, there are two reasons 
why it is more practical to maintain a separate vector for each publication: there is likely 
to be more overlap between the vectors of subscribers to the same publication than 
between those of subscribers to different publications; and a publication is likely to want 
to present its users' collaborative filtering vectors as part of the value of its brand, not to 
be found elsewhere. Collaborative filtering vectors are therefore also maintained by the 
relevant Netpage Publication Server. 

Contact details, including name, street address, ZIP Code, state, country, telephone num- 
bers, etc., are by their nature global and are maintained by a Netpage Registration Server. 

Presentation preferences, including those for quantities, dates and times discussed in Sec- 
tion 6. 1, are likewise global and maintained in the same way. 

The localization of advertising relies on the locality indicated in the user's contact details, 
while the targeting of advertising relies on personal information such as date of birth, gen- 
der, marital status, income, profession, education, etc., or qualitative derivatives such as 
age range and income range. 

For those users who choose to reveal personal information for advertising purposes, the 
information is maintained by the relevant Netpage Registration Server. In the absence of 
such information, advertising can be targeted on the basis of the demographic associated 
with the user's ZIP or ZIP+4 Code. 

Each user, pen, printer, publisher and publication is assigned its own globally unique iden- 
tifier, and the Netpage Registration Server maintains the relationships between them. 

Each user may be authorized to use any number of printers, and each printer may allow 
any number of users to use it. Each user has a single default printer, to which periodical 
publications are delivered. The server keeps track of which publishers a user has autho- 
rized print to the user's default printer. 

Each user may have several pens, but a pen is specific to a single user. If a user is autho- 
rized to use a particular printer, then that printer recognizes any of the user's pens. 

These relationships are illustrated in Figure 3. 
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Figure 3. User registration relationships 

The pen identifier is used, in the form of a URN, to locate the corresponding user profile 
maintained by a particular Netpage Registration Server, via the DNS in the usual way. 

A Web terminal can be authorized to print on a particular Netpage Printer, allowing Web 
pages and Netpage documents encountered during browsing to be conveniently printed on 
the nearest Netpage Printer. 

6.4 Intelligent Page Layout 

The Netpage Publication Server automatically lays out the pages of each user's personal- 
ized publication on a section-by-section basis. Since most advertisements are in the form 
of pre- formatted rectangles, they are placed on the page before the editorial content. 

The advertising ratio for a section can be achieved with wildly varying advertising ratios 
on individual pages within the section, and the ad layout algorithm exploits this. The algo- 
rithm attempts to co- locate closely tied editorial and advertising content, e.g. ads for roof- 
ing material placed specifically with the publication because of a special feature on 
do-it-yourself roofing repairs. 

The editorial content selected for the user, i.e. text with associated images and graphics, is 
then laid out according to various aesthetic rules. 

The entire process, including the selection of ads and the selection of editorial content, 
must be iterated once the layout has converged, to attempt to more closely achieve the 
user's stated section size preference. The section size preference can, however, be 
matched on average over time, allowing significant day-to-day variations. 

6.5 Document Format 

Once the document is laid out, it is encoded for efficient distribution and persistent storage 
on the Netpage Network. 

The primary efficiency mechanism is the separation of information specific to a single 
user's edition and information shared between multiple users' editions. The specific infor- 
mation consists of the page layout. The shared information consists of the objects to which 
the page layout refers, including images, graphics, and pieces of text. 
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A text object contains fully- formatted text represented in the Extensible Markup Lan- 
guage (XML) [67] using the Extensible Stylesheet Language (XSL) [68]. XSL provides 
precise control over text formatting independently of the region into which the text is 
being set, which in this case is being provided by the layout. The text object contains 
embedded language codes to enable automatic translation, and embedded hyphenation 
hints to aid with paragraph formatting. 

An image object encodes an image in the JPEG 2000 wavelet-based compressed image 
format [33]. The original DCT-based JPEG algorithm introduces negligible visual loss at 
compression ratios below 10:1 [64]. JPEG 2000 is planned to achieve the same quality at 
compression ratios 30% higher, i.e. at about 13:1 [34]. 

A graphic object encodes a 2D graphic in Scalable Vector Graphics (SVG) [70] format. 

The layout itself consists of a series of placed image and graphic objects, linked textflow 
objects through which text objects flow, hyperlinks and input fields as described in Sec- 
tion 5.6, and watermark regions. These layout objects are summarized in Table 3. The lay- 
out uses a compact format suitable for efficient distribution and storage. 

The layout is tagged with the version of the text-setting algorithm used by the Netpage 
Publication Server when the layout was first created, allowing the Netpage Printer to 
exactly reproduce the physical layout intended by the server. 

Because Netpage Printer software is automatically upgraded over the Netpage Network, it 
is feasible for Netpage Printers to contain every version of the text-setting algorithm. 



Table 3. Netpage layout objects 
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6.6 Document Distribution 

As described above, for purposes of efficient distribution and persistent storage on the 
Netpage Network, a user-specific page layout is separated from the shared objects to 
which it refers. 
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When a subscribed publication is ready to be distributed, the Netpage Publication Server 
allocates, with the help of the Netpage Id Server, a globally unique id for each page, page 
instance, document, and document instance. 

The server computes a set of optimized subsets of the shared content and creates a multi- 
cast channel for each subset, and then tags each user-specific layout with the names of the 
multicast channels which will carry the shared content used by that layout. The server then 
pointcasts each user's layouts to that user, and when the pointcasting is complete, multi- 
casts the shared content on the specified channels. After receiving its pointcast, each 
Netpage Printer subscribes to the multicast channels specified in the page layouts. During 
the multicasts, each printer extracts from the multicast streams those objects referenced by 
its page layouts. 

Once a printer has received all the objects to which its page layouts refer, the printer 
re-creates the fully-populated layout and then rasterizes and prints it. 

The server also delivers each page layout to the relevant Netpage Page Server, which may 
be co-located with the Netpage Publication Server, or may be located elsewhere on the 
network. Thus the page layouts are persistency archived as Netpages. It is the responsibil- 
ity of the Netpage Publication Server to preserve the shared objects referenced by the 
Netpages, to ensure that they are really persistent. It may choose to archive these shared 
objects elsewhere on the network at any time. The object URIs embedded in the Netpages 
allow the objects to move. 

Under normal circumstances, the printer prints pages faster than they can be delivered. 
Assuming a quarter of each page is covered with images, the average page has a size of 
less than 400KB *. The printer can therefore hold in excess of 100 such pages in its internal 
64MB memory, allowing for temporary buffers etc. The printer prints at a rate of one page 
per second. This is equivalent to 400KB or about 3Mbit of page data per second, which is 
similar to the highest expected rate of page data delivery over a broadband network. 

Even under abnormal circumstances, such as when the printer runs out of paper, it is likely 
that the user will be able to replenish the paper supply before the printer's 100-page inter- 
nal storage capacity is exhausted. 

However, if the printer's internal memory does fill up, then the printer will be unable to 
make use of a multicast when it first occurs. The Netpage Publication Server therefore 
allows printers to submit requests for re-multicasts. When a critical number of requests is 
received or a timeout occurs, the server re-multicasts the corresponding shared objects. 

Once a document is printed, a Netpage Printer can produce an exact duplicate at any time 
by retrieving its page layouts from the relevant Netpage Page Server and retrieving the 
objects to which they refer from the network. 



When a Netpage document is requested ad hoc, it is personalized and delivered in much 
the same way as a periodical. However, since there is no shared content, delivery is made 
directly to the requesting printer, i.e. without the use of multicast. 



1. 267 pixels per inch (ppi) 24-bit RGB, compressed using JPEG 2000 at a ratio of 13: 1. 



6.7 



On-Demand Documents 
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When a non-Netpage document is requested ad hoc, it is not personalized, and it is deliv- 
ered via a designated Netpage Formatting Server which reformats it as a Netpage docu- 
ment. A Netpage Formatting Server is a special instance of a Netpage Publication Server. 
The Netpage Formatting Server has knowledge of myriad Internet document formats, 
including old favorites such as Adobe's Portable Document Format (PDF) [3], and Hyper- 
text Markup Language (HTML) [69]. In the case of HTML, it makes use of the higher res- 
olution of the printed page to present Web pages in a two-column format, with a table of 
contents and an index of links. By default it automatically includes all Web pages directly 
linked to the requested page. The user can tune this behavior via a preference. 

The Netpage Formatting Server makes standard Netpage behavior, including interactivity 
and persistence, available on any Internet document, no matter what its origin and format 
It hides knowledge of different document formats from both the Netpage Printer and the 
Netpage Page Server. 
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7 Security 



7.1 



Cryptography 



Cryptography is used to protect sensitive information, both in storage and in transit, and to 
authenticate parties to a transaction. There are two classes of cryptography in widespread 
use: secret-key cryptography and public-key cryptography. The Netpage Network uses 
both classes of cryptography. 

Secret-key cryptography, also referred to as symmetric cryptography, uses the same key to 
encrypt and decrypt a message. Two parties wishing to exchange messages must first 
arrange to securely exchange the secret key. 

Public-key cryptography, also referred to as asymmetric cryptography, uses two encryp- 
tion keys. The two keys are mathematically related in such a way that any message 
encrypted using one key can only be decrypted using the other key. One of these keys is 
then published, while the other is kept private. The public key is used to encrypt any mes- 
sage intended for the holder of the private key. Once encrypted using the public key, a 
message can only be decrypted using the private key. Thus two parties can securely 
exchange messages without first having to exchange a secret key. To ensure that the pri- 
vate key is secure, it is normal for the holder of the private key to generate the key pair. 

Public-key cryptography can be used to create a digital signature. If the holder of the pri- 
vate key creates a known hash of a message and then encrypts the hash using the private 
key, then anyone can verify that the encrypted hash constitutes the "signature" of the 
holder of the private key with respect to that particular message, simply by decrypting the 
encrypted hash using the public key and verifying the hash against the message. If the sig- 
nature is appended to' the message, then the recipient of the message can verify both that 
the message is genuine and that it has not been altered in transit. 

To make public-key cryptography work, there has to be a way to distribute public keys 
which prevents impersonation. This is normally done using certificates and certificate 
authorities. A certificate authority is a trusted third party which authenticates the connec- 
tion between a public key and someone's identity. The certificate authority verifies the 
person's identity by examining identity documents etc., and then creates and signs a digi- 
tal certificate containing the person's identity details and public key. Anyone who trusts 
the certificate authority can use the public key in the certificate with a high degree of cer- 
tainty that it is genuine. They just have to verify that the certificate has indeed been signed 
by the certificate authority, whose public key is well-known. 

In most transaction environments, public-key cryptography is only used to create digital 
signatures and to securely exchange secret session keys. Secret-key cryptography is used 
for all other purposes. 

In the following discussion, when reference is made to the secure transmission of informa- 
tion between a Netpage Printer and a server, what actually happens is that the printer 
obtains the server's certificate, authenticates it with reference to the certificate authority, 
uses the public key-exchange key in the certificate to exchange a secret session key with 
the server, and then uses the secret session key to encrypt the message data. A session key, 
by definition, can have an arbitrarily short lifetime. 
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7.2 Netpage Printer Security 

Each Netpage Printer is assigned a pair of unique identifiers at time of manufacture which 
are stored in read-only memory in the printer and in the Netpage Registration Server data- 
base. The first id is public and uniquely identifies the printer on the Netpage Network. The 
second id is secret and is used when the printer is first registered on the network. 

When the printer connects to the Netpage Network for the first time after installation, it 
creates a signature public/private key pair. It transmits the secret id and the public key 
securely to the Netpage Registration Server. The server compares the secret id against the 
printer's secret id recorded in its database, and accepts the registration if the ids match. It 
then creates and signs a certificate containing the printer's public id and public signature 
key, and stores the certificate in the registration database. 

The Netpage Registration Server acts as a certificate authority for Netpage Printers, since 
it has access to secret information allowing it to verify printer identity. 

When a user subscribes to a publication, a record is created in the Netpage Registration 
Server database authorizing the publisher to print the publication to the user's default 
printer. Every document sent to a printer is addressed to a particular user and is signed by 
the publisher using the publisher's private signature key. The printer verifies, via the regis- 
tration database, that the publisher is authorized to print the publication on the specified 
user's default printer and that the printer is the user's default printer. The printer verifies 
the signature using the publisher's public key, obtained from the publisher's certificate 
stored in the registration database. 

The Netpage Registration Server accepts requests to add printing authorizations to the 
database, so long as those requests are initiated via a pen registered to the printer. 

The user can authorize a Web terminal to print on a printer. This is useful if the user has a 
Web terminal in the home which is used to locate documents on the Web for printing. The 
one-time authorization proceeds as follows: the user prints a Web terminal authorization 
form. The Netpage Registration Server generates a short- lifetime one-time-use id for the 
Web terminal which is printed on the form, together with the URI of the printer. The Web 
terminal is used to navigate to a Netpage Registration Server registration site, where the 
one-time-use id is entered, as well as the URJ of the printer. The Web terminal generates a 
signature public/private key pair. The server allocates a terminal id for the Web terminal, 
creates and signs a certificate containing the terminal id and the public key, and stores the 
certificate in the registration database. The URI of the printer, the Web terminal's terminal 
id, and the private signature key are stored locally on the Web terminal. 

Whenever the Web terminal wishes to print on the printer, it sends the printer's designated 
Netpage Formatting Server a request containing the URI of the document to be printed, 
together with the terminal id, signed with the Web terminal's private signature key. On 
receipt of the request and before acting on it, the server verifies, via the registration server, 
that the terminal is authorized to print on the specified printer, and verifies the signature 
using the terminal's public key, obtained from the terminal's certificate stored in the regis- 
tration database. 

The user can print a list of current printing authorizations at any time, and revoke any 
which are being abused. 
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7.3 



Netpage Pen Security 



Each Netpage Pen is assigned a unique identifier at time of manufacture which is stored in 
read-only memory in the pen and in the Netpage Registration Server database. The id 
uniquely identifies the pen on the Netpage Network. 

A Netpage Pen can know a number of Netpage Printers, and a printer can know a number 
of pens. A pen communicates with a printer via a radio frequency signal whenever it is 
within range of the printer. Once a pen and printer are registered, they regularly exchange 
session keys. Whenever the pen transmits digital ink to the printer, the digital ink is always 
encrypted using the appropriate session key. Digital ink is never transmitted in the clear. 

A pen stores a session key for every printer is knows, indexed by printer id, and a printer 
stores a session key for every pen it knows, indexed by pen id. Both have a large but finite 
storage capacity for session keys, and will forget a session key on a least-recently-used 
basis if necessary. 

When a pen comes within range of a printer, the pen and printer discover whether they 
know each other. If they don't know each other, then the printer determines whether it is 
supposed to know the pen, i.e. because the pen belongs to a user who is registered to use 
the printer. If the printer is meant to know the pen but doesn't, then it initiates the auto- 
matic pen registration procedure. If the printer isn't meant to know the pen, then it agrees 
with the pen to ignore it until the pen is placed in a charging cup, at which time it initiates 
the registration procedure. 

In addition to its public id, the pen contains a secret id and a secret key-exchange key, both 
intended for one-time use. These are also recorded in the Netpage Registration Server 
database at time of manufacture. During registration, the printer obtains the secret id from 
the pen. Because it is transmitted in the clear, it may be intercepted by someone listening 
in. The printer transmits the id securely to the Netpage Registration Server, which 
responds securely with the matching key-exchange key, together with a newly-generated 
secret id and key-exchange key. The printer generates a session key for the pen and trans- 
mits it to the pen encrypted using the one-time- use key-exchange key. It also securely 
transmits the new secret id and key -exchange key to the pen, which saves them for the 
next registration procedure. They now match the pen's record in the Netpage Registration 
Server database. 

If the secret id transmitted in the clear from the pen to the printer is intercepted and used to 
retrieve the secret key-exchange key from the Netpage Registration Server before the 
printer queries the server, then the server rejects the printer's query because the secret id is 
out-of-date. Thus the printer knows that the pen has been compromised, and recommends 
that it be returned for repair. 

When a previously unregistered pen is first registered, it is of limited use until it is linked 
to a user. A registered but "un-owned" pen is only allowed to be used to request and fill in 
Netpage user and pen registration forms [2], i.e. to register a new user to which the new 
pen is automatically linked, or to add a new pen to an existing user. 

The pen uses secret-key rather than public-key encryption because of hardware perfor- 
mance constraints in the pen. 
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7.4 



Secure Documents 



The Netpage System supports the delivery of secure documents such as tickets and cou- 
pons. The Netpage Printer includes a facility to print watermarks, but will only do so on 
request from publishers who are suitably authorized. The publisher indicates its authority 
to print watermarks in its certificate, which the printer is able to authenticate. 

The 'Svatermark" printing process uses an alternative dither matrix in specified "water- 
mark" regions of the page. Back-to-back pages contain mirror-image watermark regions 
which coincide when printed. The dither matrices used in odd and even pages' watermark 
regions are designed to produce an interference effect when the regions are viewed 
together - i.e. when looking through the printed sheet. 

The effect is similar to a watermark in that it is not visible when looking at only one side 
of the page, and is lost when the page is copied by normal means. 

As described in Section 5.8, pages of secure documents cannot be copied using the built-in 
Netpage copy mechanism. This extends to copying Netpages on Netpage-aware photo- 
copiers. 

Secure documents are typically generated as part of e-commerce transactions. They can 
therefore include the user's photograph which was captured when the user registered bio- 
metric information with the Netpage Registration Server, as described in Section 8. 

When presented with a secure Netpage document, the recipient can verify its authenticity 
by requesting its status in the usual way. The unique id of a secure document is only valid 
for the lifetime of the document, and secure document ids are allocated non-contiguous ly 
to prevent their prediction by opportunistic forgers. A secure document verification pen 
can be developed with built-in feedback on verification failure, to support easy 
point-of-presentation document verification. 

Clearly neither the watermark nor the user's photograph are secure in a cryptographic 
sense. They simply provide a significant obstacle to casual forgery. Online document veri- 
fication, particularly using a verification pen, provides an added level of security where it 
is needed, but is still not entirely immune to forgeries. 



In the Netpage System, forms submitted by users are delivered reliably to forms handlers 
and are persistently archived on Netpage Page Servers. It is therefore impossible. for recip- 
ients to repudiate delivery. 

E-commerce payments made through the system, as described in Section 8, are also 
impossible for the payee to repudiate. 



7.5 



Non-Repudiation 
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8 Electronic Commerce Model 

8.1 Secure Electronic Transaction (SET) 

The Netpage System uses the Secure Electronic Transaction (SET) [42] system as its nav- 
ment system model. Although SET is not yet widely supported, it is comprehens veTd 
elegant and will probably become dominant in the near future. 

a S n E 7;h haVing n 6n d * Vel T d by MasterCarf Visa, is organized around payment cards 
and this is reflected in the terminology. However, much of the system is independent of 
the type of accounts being used. 

In SET, cardholders and merchants register with a certificate authority and are issued with 
certificates containing their public signature keys. The certificate authority verifies a card- 
holder s registration details with the card issuer as appropriate, and verifies a merchant's 
registration details w.th the acquirer as appropriate. Cardholders and merchants store their 
respective private signature keys securely on their computers. During the payment pro- 
cess, these certificates are used to mutually authenticate a merchant and cardholder and to 
authenticate them both to the payment gateway. 

SET has not yet been adopted widely, partly because cardholder maintenance of keys and 
certificates is considered burdensome. Interim solutions which maintain cardholder keys 
s^me C s^ccesTtls" * ^ ^ Cardh °' der access via a Password have met with 

8.2 SET Payments 

!rJ r h r N T ge ^7 the Netpage Registration Server acts as a proxy for the Netpage 
user (i.e. the cardholder) in SET payment transactions. 

The Netpage System uses biometrics to authenticate the user and authorize SET payments 
Because the system is pen-based, the biometric used is the user's on-line signature con- 
sisting of tune-varying pen position, tilt and pressure. A fingerprint biometric can also be 
used by designing a fingerprint sensor into the pen, although at a higher cost The type of 
theTystem ^ ° f biometric ' not the authorization aspects of 

bCing . ablC t0 makC SET P avment s is to register the user's biometric with 
the Netpage Registration Server. This is done in a controlled environment, for example a 
the Metric can be captured at the same time as the user's identity is veri- 
fied. The biometric is captured and stored in the registration database, linked to the user's 

anTr^ £ H /rTL° f 3 r tiCU,ar NetpagC Pea 1116 USer ' s P^tograph is also option- 
a ly captured and linked to the record. The SET cardholder registration process is com- 
pleted, and the resulting private signature key and certificate are stored in the database 
The user s payment card information is also stored, giving the Netpage Registration 
Server enough information to act as the user's proxy in any SET payment transaction. 

When the user eventually supplies the biometric to complete a payment, for example by 
signing a Netpage order form, the printer securely transmits the order information, the pen 
.d and the biometnc data to the Netpage Registration Server. The server verifies the bio- 
metric with respect to the user identified by the pen id, and from then on acts as the user's 
proxy in completing the SET payment transaction 
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8.3 Micro-Payments 

The Netpage Network includes a mechanism for micro-payments, to allow the user to be 
conveniently charged for printing low-cost documents on demand and for copying copy- 
right documents, and possibly also to allow the user to be reimbursed for expenses 
incurred in printing advertising material. The latter depends on the level of subsidy 
already provided to the user. 

When the user registers for e-commerce, a network account is established which aggre- 
gates micro-payments. The user receives a statement on a regular basis, and can settle any 
outstanding debit balance using the standard payment mechanism. 

The network account can be extended to aggregate subscription fees for periodicals, which 
would also otherwise be presented to the user in the form of individual statements. 



8.4 Transactions 

Whenever a transaction originates through a Netpage form, the form handler has sufficient 
information, in the shape of the form's unique document instance id, to maintain transac- 
tion-specific state information. However, a transaction may also originate through a 
non-form page such as a printed catalog page, implying, for example, the existence of a 
virtual "shopping cart". In this case the relevant transaction state information is tied, indi- 
rectly, to the unique id of the user. 

The Netpage Registration Server maintains an anonymous relationship between a user and 
a transaction handler via a uniquely numbered transaction, as illustrated in Figure 4. 
Whenever the user activates a hyperlink tagged with the "transaction" attribute, the 
Netpage Printer asks the Netpage Registration Server to translate the associated handler 
id, together with the pen id, into a transaction id. The transaction id is then submitted to 
the hyperlink transaction handler. For efficiency, the printer caches transaction ids. 

The transaction handler maintains state information indexed by transaction id. It is able to 
retrieve user-specific state information without explicit knowledge of the user. 



traneaction 



transaction 
handler 



Figure 4. User transaction 
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9 Applications 



The Netpage Network has the potential to subsume a wide variety of applications in both 
traditional and electronic media. This section sketches the following possibilities: 

• personalized subscriptions to newspapers, magazines and comics 

• subscriptions to freelance columns and bulletin boards 

• on-demand newspapers, magazines and comics 

• on-demand flyers and product brochures 

• on-demnnd books 

• television infotainment printing 

• e-commerce purchasing from online and traditional catalogs 

• delivery of statement and invoices, with online payment 

• delivery of secure document (tickets, coupons and licenses) 

• perfect copying with copyright micro-payments 

• mail replacement 

• delivery of greeting cards 

• form printing, fill-in, and submission 

• delivery of e-mail and facsimile 

• active business cards 

• on-demand document delivery on corporate intranets 

• provision of government services 

• Web browsing, searching and printing 

• photo album creation 

• persistent searchable note taking 

• exam taking and homework 

• computer printing 

Many of these applications are described in detail in [2]. 



The strength of the Netpage Network lies in automatically delivering subscribed periodi- 
cals, at a print quality equalling or exceeding that of their traditional counterparts, with 
editorial content personalized to individual interests, advertising content localized and tar- 
geted to individual localities and demographics, and advertising directly linked to detailed 
product information and product purchasing. 



The Netpage Network offers a new delivery mechanism to the $24 billion newspaper and 
newsmagazine market which is both more cost-effective than centralized printing and dis- 
tribution, and allows more fine-grained targeting of advertising. 

The simplest form of news personalization involves selecting a news publication and 
choosing which daily and weekly sections to receive. The simplest form of advertising 
personalization is tuned to the demographics associated with the subscriber's ZIP or 
ZIP+4 code. Even with these entry-level forms of personalization, the Netpage Network 
offers a compelling distribution model for news. 



9.1 



Personalized Subscriptions 



9.1.1 



Newspapers and Magazines 
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Users receive paper publications with the usability of their traditional counterparts but 
with interactive properties. At the press of an on-page button, a user can print an article 
giving the background to a news story, print a personalized product brochure or add a 
product to the virtual shopping basket 

Any magazine normally printed on lightweight paper stock is equally well-suited to distri- 
bution on the Netpage Network. However, since Netpage Printers don't carry heavier 
paper stocks and don't provide wrap-around binding, the Netpage Network is less 
well-suited to the distribution of so-called "glossy" magazines. 

9.1.2 Freelance Columns and Bulletin Boards 

Users can choose to subscribe to individual freelance columns, cartoons, etc. These can be 
integrated into a user's daily news document, or printed individually. Freelancers can 
choose to receive micro-payments from their subscribers, freeing them from maintaining 
their own subscriber databases. The Netpage Network provides mechanisms for handling 

micro-payments. & 

Users can also subscribe to the "bulletin boards" of friends: collections of news 
announcements, pictures etc., which work much like freelance columns. 

9.2 On-Demand Publications 

The Netpage Network can deliver, on demand, current and back issues of periodicals nor- 
mally delivered on subscription, including newspapers, magazines, and comics. To main- 
tarn the interactivity of all Netpages ever printed, the Netpage Network keeps all 
published content online at all times. Unlike the Web, where hyperlinks become unreliable 
over time, content on the Netpage Network never expires. 

9.2.1 Flyers and Product Brochures 

The Netpage Network makes high-quality flyers and product brochures instantly avail- 
able, linked to advertisements and entries in printed catalogs. 

Brochures are always up-to-date, and link to e-commerce, e-mail, and automatic telephone 
call-back. Brochure links can provide "click-through" fees to linking documents, and sub- 
sidized printing to users. 

Active Netpage advertisements can appear in printed paper publications sold or delivered 
through traditional outlets, including newspapers and magazines sold on news stands 
posters appearing in public places (including in buses, trains and taxis), and books sold in 
bookshops. Buying guides and travel guide books are particularly suited to containing 
active Netpage advertising. 



9.2.2 Books 



Users can obtain the latest best-sellers or rare "out-of-print" (a soon-to-obsoleted term) 
editions on demand, printed in column format with a text size chosen by the user A typi- 
cal 300-page paperback fits on as little as 40 sheets of Letter paper. Slip-on covers are 
available for robust handling. 

Titles which have outlived their copyright period are available for free. Other titles are 
heavily discounted for Netpage delivery, since publishers avoid the costs of printing 
inventory storage, and delivery. 
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Colorful children's books reproduce immaculately. When they've been loved to death, 
they can be printed again, and again. 

Children's coloring-in books and puzzles are available just when they're needed on a rainy 

day. 

9 2 3 Television Infotainment 

material . I^^SSOTiyr. £Z£ precede, the 
taTsubscriptionfom. tor the print publication the prog™ .s promohng. 

rS^r^r'Tsce^ which*** it to — 

^^"SL^SiTS^i-Ji da,. and dm. 

rem^es the document from the document server based on date and tune. 

signal itself, tor example <u> <x ^ :„ teri/a i rVRH The advantage of leveraging 

room for information in the vert.cal b among m »J^2^£n Coders are now 
support for closed captioning, » J^^^J^S^tag is fully sup- 
^dtT^ W Other VBI-based 

SS« J cus^coders and may not survive the transition to d.grtal telev.s.on. 

9.3 e -Commerce 

9.3.1 Online Purchases 

rSaU234 e 5= U^irCuLTs signal authorize, me payment. 

9 3 2 Catalog Purchases 

Rather than buying from an online Netpage catalog, the user can select .tems from a trad,- 
tionally-printed catalog which contains active Netpage links. 
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9.3.3 Statements and Invoices 

Statements and invoices can be securely and auditablv rf^ii™^ a 

The user's signature can authorize the payment as normal. 

9.3.4 Secure Documents 

JESS^tS^* 1 "" *" d "" pons — *■ ^ ^ * 

As described earlier, recipients can verify the authentic, ^ 

standard Netpage Printer or a special verScatn ptn ^ d ° CUmentS " Sing 3 

9.3.5 Copyright Copying 

micro-paynLt from th^iTote t^gSST^ °" ^ 3 

nient' SlS^^^S^ but ""*» P- because of the inconve- 

original copy. ^ micr °-P^^ convenience and the quality of an 

9-4 Communication 

9-4.1 Mail 

SSSS: b r bC ^ t0 de,iVer ™ dances 
already describe^ tteZplZ X^^Tr™^?**™"* fa SeCti °" 9 ^ As 
recipient. P 8 y ™ ° nly dd,vers mai1 from sources authorized by the 

The United States Postal Service delivers 107 000 finnnnn • 

year [64], a large number of which are iSat^ ^ Ch " ^ each 

9.4.2 Greeting Cards 

^T^'^k^^^ • Written message, and 
to normal postal addreTses [7^1^ T be j lddressed to °ther Netpage users, and 

« the recipTent, Ju^^^^^^^tT^^^ 
system. P envelope, and mailed through the local mail 

Netpage users can choose to receive cards from anyone, or only from authorized friends. 

9.4.3 Forms 
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Handwriting is automatically recognized by the system. The digital ink of the handwriting 
is attached to the form in case a human clerk needs to re-interpret the handwriting. Auto- 
matic "handwriting bots" on the network can assist with the recognition task, automati- 
cally giving the user semi-intelligent feedback to elicit disambiguation. 

Any interactive Netpage "application", including e-commerce and e-mail, uses forms of 
various kinds. 

9.4.4 E-Mail 

E-mail forms can be printed on demand and filled in by hand. The handwritten name of 
the recipient is convened to facilitate delivery, but the rest of the message is delivered as 
digital ink, just as the uao intended, if the recipient is computer-based rather than 
Netpage-based, all of the handwriting can be automatically converted, with the digital ink 
sent as an attachment (since it may contain hand-drawn diagrams etc). 

Netpage users can choose to receive e-mail from anyone, or only from authorized friends. 

Each user maintains a list of contacts which allows e-mail to be addressed by name. Users 
never deal with Netpage user ids directly. If the specified name is ambiguous, the system 
prints a list of choices. The use of nicknames helps to avoid ambiguity. 

9.4.5 Business Cards 

Each user's business card can act as a convenient one-time e-mail authorization token. It is 
encoded as a Netpage and contains a button which, when pressed by the card recipient, 
adds the card owner to the recipient's contact list and authorizes the recipient to send the 
card owner e-mail. 

The business card can also contain buttons which link to company information, personal 
information, and even product information if the user is a salesperson. 

The Netpage Network provides a bureau service which allows users to order active 
Netpage business cards. 

9.4.6 Facsimile 

Facsimile forms can be printed on demand and filled in by hand. The handwritten tele- 
phone number is converted to facilitate delivery, but the rest of the message is delivered as 
bitmapped digital ink, just as the user intended. 

9.4.7 Conferencing 

Geographically distributed participants can communicate graphical ideas via a shared 
Netpage "whiteboard" while engaged in a telephone conference. Every time a participant 
adds a modification or a new diagram to the whiteboard the other participants are given a 
new copy of the page. New pages can be started at any time, but older pages or older ver- 
sions of pages can still be marked up and re-distributed. Each participant ends up with a 
full history of the interaction. Multiple colors and line styles can be chosen from a palette. 
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9-5 Corporate and Government 

9.5.1 Corporate Intranets 

An organization can use a private intranet-based Netoaee Network t« . , 

ment repository and efficiently distribute documentsTdema^ ' **- 

9.5.2 Government Services 

9.6 Personal 



9.6.1 



Web Browsing, Searching and Printing 

«. index oS„c^T£ 6 •** ' »"* of »" 

«. on P a^, .-s^ss^^s^*-- ™ us ,he user - 200 



9.6.2 Photo Album 



9-6.3 Notebook 
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patent application. Since the handwriting is recognized and converted to text for indexing 
purposes, the notes can also be searched by keyword, date, etc. 

9.6.4 Examination Papers and Homework 

Students can sit exams in a controlled manner while physically distant from the classroom. 

An examination paper can be delivered at a specific time to a distributed collection of stu- 
dents. The students can then be required to answer the questions on the paper within the 
allotted time. Their answers can be automatically captured at the end of the allotted time 
using the "blackboard" form model, and in many cases automatically graded. Once again, 
unrecognized input can be routed to a human operator. 

Multiple choice questions can be automatically graded. 

Homework in general can be distributed and captured in a similar way. 

9.6.5 Computer Printing 

A Netpage Printer can be the ideal output device for a personal computer or workstation, 
whether directly-connected or on a local-area network. The speed of the Netpage Printer 
and the quality of its output make it attractive to existing computer users. 

The Netpage Printers have a USB port as a standard feature. 
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10 Business Models 



10.1 System Principles 

The Netpage Network leverages the open technology and extensive infrastructure of the 
Internet. The widespread acceptance and growth of the Netpage Network is predicated on 
open competition rather than monopolistic practices. 

However, to provide an incentive to early investors, semi-exclusive licenses to Mem- 
jet-based Netpage Printer designs will be offered, as well as licenses to manufacture paper 
and ink consumables. 




Figure 5. Open structure of Internet-based Netpage Network 

The network supports any number of independent participants, some of which have com- 
plementary roles, and some of which compete. The open structure of the network is illus- 
trated in Figure 5. Content-related participants include the following: 

• news sources 

• publishers 

• news aggregators 

• freelance artists, writers, cartoonists 

• direct mailers 

• advertisers 

• advertising aggregators 

• banks 

• merchants 
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Infrastructure-related participants include the following: 

• server suppliers 

• network storage providers 

• communications carriers 

• Internet service providers (ISPs) 

• printer dealers 

• printer installation and servicing companies 

• ink and paper consumables dealers 

• consumables delivery companies 

Technology-related participants include the following: 

• research and development 

• chip makers (printheads, controllers, QA) 

• printer manufacturers 

• ink and paper consumables manufacturers 

The strength of the network lies in the fact that publication and delivery are completely 
decoupled. This allows the delivery infrastructure to grow independently of the participa- 
tion of publishers. 



Because consumers are unlikely to be motivated to acquire a Netpage Printer until a vari- 
ety of publications and services are available, and because publishers will wait for an 
installed base before participating, the key to bootstrapping the network is to bundle the 
printer with a publication or service subscription, and possibly trimming profit margins in 
the growth stage. 

There are several ways the manufacturing cost of the Netpage Printer, assumed to be well 
below $100, can be subsidized. Printer-based distribution can eliminate existing distribu- 
tion costs, offsetting the printer cost. The printer can provide a new mechanism for deliv- 
ering advertising, with advertising profits offsetting the printer cost. And the printer cost 
can be built into the subscription fee for a publication or service. 

The cost of printing and delivering a newspaper normally exceeds the price of subscrip- 
tion [26,50]. The real profit lies in the advertising. The cost of the Netpage Printer is easily 
exceeded by one years' cost savings, allowing a Netpage subscription, including a "free" 
printer, to be priced lower than a traditional subscription. A Netpage subscription offered 
to a customer already on the network would be priced correspondingly lower still. 

If the publication or service delivered via the Netpage Printer is sufficiently lucrative, then 
the publisher or provider may be able to subsidize not only the printer itself, but also its 
running costs. This can include Internet access, paper and ink consumables, and servicing. 
Demographics-informed advertising may fall into this category. The more information 
customers reveal about themselves, the greater the value of the advertising to the advertis- 
ers, and so the greater the level of subsidization that can take place. 

Early investors who subsidize the installation of Netpage Printers may be able to recover 
the investment and turn a profit merely by charging other publishers an access fee to the 



10.2 



Bootstrapping 
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pnnters they own", perhaps for an interim period after installation, according to a net- 
work-w.de agreement. They may also be able to earn commissions on click-throughs £d 
e-commerce transact,ons originating on pages printed on "then- printers. 

S^-ST 0 !?? ™" lrea4y emergia& ' m 016 general Intemet market. In the TreePC" 

wh 0 .7nit t, P 61 ' PerS ° nal C ° mpUtere « bund,ed with ^et access «2 *e 
whole package ,s folly or partially subsidized by advertising and e-commerce. 

vt^c^ " *? Netp3ge NetWOrk » "« even Fernet service pro- 

viders, can benefit from directly investing in Netpage Printer deployment. 

10.3 Maturity 

JIZJ* ^ bund " ng a PP roach « are likely to remain applicable once the network 
becomes widely subscribed. It is possible that the bundling of the appliance fie me 
Netpage Printer with the service (be it Internet access or a publication sESion) w^ 
remain the dominant means of distributing the appliance, as'it is in the SKSS 
market and as an .ncreasing number of companies, including IBM [17] are begmnui to 
believe it should be in the personal computer market. beginning to 

10.3.1 News Publishers and News Aggregators 

S^J^'-SbTT* brands ™ Iike,y to te ab!e leverage those brands « the 

Netpage Network. They have an incentive to do so quickly to prevent newcomers from 
filling the vacuum and capturing the attendant advertising revenue. newCOmers from 

alLw?^^ 50 JIT a " "T 1 " l ° m, ' 8rate t0 thC N£t P age Network b ^use it 

d Zdin e and wS£.? ^ ftw *™ inBd ta ^ eting » at Risers are increasingly 
demanding, and which they are increasingly seeking elsewhere. 

News publishers who create content rather than simply aggregating other sources have a 
S1 gn,f,cant advantage, since they offer both unique contenfand an editorial vo ce ulers 

tionX re F H 3 SingIC nCWS PUbHcati0n whose conte "' and edltor^nS 

of din/J ' than SPeCifyin8 t0 3 " eWS Wtaw to glue together a number 

of disparate news sources. And any sufficiently strong news publication brand is un"fce!v 
to make its content available to an aggregator, since the aggregator wfll bTSS^t? 
portion of advertising and e-commerce revenue. 8 P 

The Netpage Network, like the Web, offers lower barriers to entry than traditional publish- 
ing med.a, and this naturally stimulates greater diversity. However, the 

£S£? netW ° rk ' COUP ' ed Wkh built - in --danisms for^ocS ion of 

pubI.cat.ons, allows international, national and regional news publications to more easUv 
compete m local news markets. w»m> io more easily 

The strength of a traditional local news publication lies partly in its local news content and 
partly in its local retail advertising and classified advertising content. Agg^gaUWcSs 

adVertiSine - ^ " eWS P ub,icatio - «• therefore 
nicely to be excluded from the direct capture of local advertising, and may instead trans 
form themse.ves mto news gatherers feeding localized editions otlarger pu^Hcadons 
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1 0.3.2 Advertising Aggregators 

The Netpage Network promises to be the most effective advertising medium ever con- 
ceived. It combines the editorial and print quality of traditional publications with arbi- 
trarily finely targeted advertising, and provides a direct link between advertising, product 
information, and purchasing. 

Because personalization and localization are handled automatically by Netpage Publica- 
tion Servers, an advertising aggregator can provide arbitrarily broad coverage of both 
geography and demographics. The subsequent disaggregation is efficient because it is 
automatic. 

This makes it more cost-effective for publishers to deal with advertising aggregators than 
to directly capture advertising. Even though the advertising aggregator is taking a propor- 
tion of advertising revenue, publishers may find the change profit-neutral because of the 
greater efficiency of aggregation. 

Because of the finer targeting supported by the Netpage Network, publishers and advertis- 
ing aggregators have a larger advertising space* to sell, leading to greater profits. The link- 
ing between advertising, detailed product information, and purchasing, and the 
corresponding measurability of consumer behavior, leads to greater profits from 
click-through fees and e-commerce commissions, benefiting publishers and advertising 
aggregators alike. 

Added revenue from these fees and commissions may even allow users' costs - printer, 
ink, paper, and Internet access - to be fully subsidized. 
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1 Netpage Applications 



1.1 



provide the user interface to the application. 
The following sections define a set of core 

registration. -«« subscrip.on J— SS^JStd tam P *.p*.«r 

iace ~ » - user - d the object 

ZdeUnfplicitly manipulated by the user through the user interface. 

OBJECT MODEL DESCRIPTION 

Bach object model is descHbedusing^ 

[U 2]. A class diagram cons **^ An association 

kinds of relationships are of interest here. »»»g™""* * instances of classes. A 
represents some kind of relationship ^^^^^^SSig^: if a class 
generalizati^ 

ling - i.e. classes of classes. 



department 



1 



lecturer 




s 


position 




tea one 



course 



name 

description 
timetable 



— 1> 



person 



name 
address 
date of birth 



G 



attends 
student — 



Figure 1. Illustrative UML class diagram 
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operations of the class senaratpH ft-*™ *u 
An association is drawn as a line ioinina h„ . 

the multiplicity of Ac moc^lSStSgS^^ 31 eW " r end 

a mutapln* of "many", i. e . w or m X£££SS " ^ Mftrtk ( *> 

name, and is also optionally labelled at eitoerTd wi^ * ,abe,,ed with ** 
An open diamond indicates an aggregation ! ° f * e coires Ponding class 
aggregator end of the association^ " (""-part-of and is drawn a tl e 

A generalization relationshin f"is a''^ ic a 

(in the form of an open '^^J^^^ *" ^ ^ " 

attr,butes only where it is defined. ' agram Wh,ch defines il * « shown with 

Figure 1 illustrates the subset of the UML cla« 

ML Class d'agram notation used here. 



User Interface Description 



Each application user interface flow is illustrate *c „ • 

command arrows. A command ^ doemM ,inked * 

result of the user pressing the com^SSSiiJ'h^ h printed as • 

command arrows are labelled with multiple fomZ^ Tu S0WXe pa ^ Some 

Netpage documents and 

* fined in by the user. -y p^s^^ which «£ 

d «^ contain generic information and 

and an application. P ' C t0 a P art| cular mteraction between the user 



Each teuma „ _ , dis , ma iconic represen[at . M _ ^ ^ ^ ^ 




Fl 9 u™ 2. Doc™.,,, icons |„ um iM ^ lce ^ 



" tUms fOT -~ — — ~ 55Sl5£srtJ 
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requests. 



in response to user requests. 



fixed information 
\va?\ab\c ^formation 

input field 

( command button^) 




|«| tet of drgg ^bte object or attributes 
Figure 3. Page layout elements 



1.3 



page layouts. A p« 8 e layout™ co*» fixed jntom ^ ^ of ^ 00t 

USER INTERFACE DESIGN GUIDELINES 
NETP l! a We, application, a Netpage Ration ^^^J^^ 
The application is largely ' *J^«^r is filling in the form. When the 

notified when the user submits a form n0 ™ ,e drfven tem ca „ approximate the 
time it takes to deliver a form .s short, '^ s J ct ™ J e with the Web. With the 

behavior of a truly ^"^j^^K a form is longer, but more impor- 
Netpage System, however, the tnne .t takes o ^ piece of 

tantly, a form is not 'S^SSpria*, which may not be prox.mate 

the user interface as being wasteful. 

„ , herefore *boove 5 a g.oo N^. .P S »» ^SS^IlSSS'iS 



1 .3.1 Input Feedback 



Feedback ith immediate feed- 

^ . _ nlis in . Netpage r . ^^KTTS^rSf 

the marking nib of the » °; „ m ^,„ d button, there k no immediate 
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series, oratransac- 



require 



1.3.2 



nonetheless provided in the shape of the next f«™ ;„ * 
fon receipt, or some other requested o^enT ™°' 

The user also uses the marking nib of th.~. . • 

^mediate interpretation, such J text editing ^2^" ^ don>t 

^ fo„owing are examples of in put ^ icalIy made ^ ^ ^ ^ 

• handwritten text 

• drawing 

• checkbox mark 

• signature 

• text editing command (strikeout etc ) 

• drag-and-drop (from list of objects etc ) 

• drag-and-.asso (from ^ Qf ^ ^ ^ ^ 

The fo,,owin g are examples of mput ^ made ^ ^ _ ^ ^ 

• selection by circumscription 

• button press 

A Minimum Unit of User Interface Output 

.^-bearing capacity eouivatent toten SVGA SZT' """ ° f h,s » "°™" 

»PP .cation i s designed „ produee , " «™Pt»er screens. So although , Nctpa . e 
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Directory Navigation 



A directoiy is an ^^Z^^^^^^ 
,fwo p^es h»l« * ^ "J *J££?£S? w» «d 200 entries, »o *« ««" 

E^i«d«=»«*sp~m r .h=s^ 

If the entire directory tits on two pa & , 
index tree. 

The indexed directory class diagram is shown in Figure 20. 





index node 




starting name 
ending name 


* 


index entry 


3: 



index node 
entry 



directory 
entry 



0,1 



1 directory 
1 object 



Figure 4. Indexed directory class diagram 

<*> Lions »hich Print the first Appear itUl «y tmt no rn.nn.ng for 

the current page, e.g. me 
<first> and <previous> buttons. 
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Each Page also contains a <search> hut**., u- L 
The directory navigation user interface flow is i Ihjstrated fa Figure 5 




Figure 5. Directory navigation user interface flow 

The meaning of the standard i 



Figure 6. 



nav lga t io „ buttons on the directory jndex ^ . ^ 
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( 




) 


( 


M 


) 


c 


« 


) 


( 


► 


) 


( 




) 



top 

up 

first 
previous 
next 
last 



Figures. Standard directory index 



navigation button 
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T starting"name to ending name 



I eta rting"narrie to~cnd\ri<^ name _ _ 
? slirtin/name fe? ending r^ame _ _ 
^ 5t5rting"name £ erring name _ 
? stertin/name fe> erring name _ _ 

T slirtin/name ending name _ _ 
T starting'name'ta ending name _ _ 
: Itarting'name"^ ending name _ _ 
? &tarting"name en^ing^name _ _ 
T Starting"name t» ending^ name _ _ 
T starting"narr»e"tc? ending^ name _ _ 
I 5tarting"name"fe? ending name 
J Iterttofnameio ending name _ 
? St^ing"name^ _. 
: slirting"name"^ ending^ name _ 
T Itarting'name'^ ending name _ 
? ^arting'name"^ ending_name _ 
^ sl£rting"name fc> ending name _ 
? starting" name" ^en^mg^ name _ 

? starting^ . 



C 



)CQC3. 



f search ^ 



Figure 7. Generic directory index page 
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3 User Registration 



^S^K PrcdiCated °" - ~™ —edge of user iden- 

• deliver personalized services to individual users independent of location 

• support authenticated transactions "em or location 

• support secure payments 

• guarantee a high level of privacy 



User Object Model 



user, as shown in the class 



Netpage 
printer 



printer id 
location 



Hetpage 
account 



balance 



contact 
details 



name 

address 

telephone 



global 
preferences 



privacy 
delivery 
localization 



Hetpaqe 
user 



user id 



Web 
terminal 




Netpage 
publication 




Netpage 
publisher 




vermin 


al id 


publication id 


publisher id 




* 

default printer 

•I I . 







Netpage 
pen 



pen Id 



biometric 



SET 
payment card 



account info 

certificate 

secret 





signature 
biometric 




signature 






fingerprint 
biometric 




fingerprint 



mailbox 



contact 
list 



1 barred user * 
, list 1 



Figure 8. User class diagram 
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gating the Web. 

A user utay have any nun.be, of pens, bu, each pen is iinked . a ,-**r — » f » 

user's pens may be used interchangeably. 

Each user ..so <- a Ne*age — ^^---J- 

contact details, including "I Z**™ 3, rfbiontetrie records, 

accounts, with which e-commerce payments can be made. 
The user's mailbox and contact list are described in Section 4. 

3.2 USER REGISTRATION USER INTERFACE 

3.2.1 He.p Pa^ ^ ^ ^ ^ ^ ^ forms: 



add user 

add pen to user 

add pen to local user 

authorize user on printer 

authorize global user on printer 

authorize terminal on printer 



interact with the Netpage Network, 
which the registration takes place. 
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Pnnrer-specific pnvileges setting is enabled. 
When privileges are enabled, the user reeistration f nrm m * u 

trator's pen. TOs is done by initialling tife „2^Tf be l authon2ed b y « adminis- 
j i«ing uie registration form m the appropriate place. 

TTie user registration user interface flow is illustrated in Figure 9. 




Figure 9. User registration user interface How 
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Add Netpaqe User 



page 



1of1 



Title 



First Name \ first name 
Nickname I nickname 
Family Name \ family name 



Street 
Address 



City 

State 

Country 

Work Fhone 




Mobile Fhone \ mobile phone number 
Home Fhone \ home phone number 



Frivacy 
Options 



Qon't publish name in global user list 
|~j Qon't publish address 

^ub//^/7 p/ion<? numbers 
Q o,/ y <?-m*// ^™ fcra*" contact 



Initialled by 
Administrator 



Frlvileges 



Administrator 




submit 



3 



Figure 10. User registration page 
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3.2.3 Pen Registration 

Additional Netpage Pens may be linked to existing users. 

submit 
(unknown user) 



add pen 
(w/ new pen) 




submit 
(w/ new pen) 



submit 

(ambiguous user) 



matching 
users 



help 
paqe 



(add pen 
(w/ old P cn )^ | 



add pen 



^■■1 — i\ submit 
add l(^/nevvpen) 
pen I ~ 



add pen to 
local user 




add pen 



Figure 11. Pen registration user interface flow 
- just 3 first name or a nid^ if^S^SZZ'^'T™ °" "? SUCh 
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™e<addpentoloc^^^^ 

to use the printer (Figure 14), with an <add pen> button next to each, 
only available to administrators. 

interface flow is illustrated in Figure 1 1 . 



trator's pen. This 
The pen registration user 





Figure 12. Pen registration page 
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Add Fen to Netpage User 
Matching User List 



• page# of# i 



Firet Name T firsifn a me ' 
Nickname T nickname 
Family Name I fa miry "name" 



i initials i initials 



add pen^ r u seV~name~ ~ 
add pen"^) i r U 5er"name" ~ 
(^f££^^ T user~name 
add pen user name 
C P en ~~ > ) ,r user name 
pen user name 
pen ^ ' user name 
C add pen~"*) i user name 
pen ^ ; user name 
£ad£p^T^ T username 
pen user name 
C a ^ perT^ i ueer name 
C ae *d perT**) [ user name 
add pen~^ i user name 
C add P er ^) [ user name 
C a ^ perT^ r user name 
C add perT^ i user name 
add pen ^ Tuser name 

raj 

P et1 ^ ' user name 



Figure 13. Pen registration - matching users page 
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Add Fen to Netpage Ueen 


i page #of#\ 


Local Ueer Liet 




C add pen 


)t ueer name 






f add pen 


)i ueer name 






f add pen 


J i user name 






f add pen 


)T user name 






C add pen 


\i ueer name 






( add pen 


V user name 






f add pen 


Si user name 






( add pen 


Ji user name 






f add pen 


Ji user name 






C add pen 


)i user name 






C add pen 


)i user name 






f add pen 


user name 






( add pen 


\i ueer name 






Q add pen 


)i user name 






Q add pen 


)T user name 






^ add pen 


user name 






Q add pen 


) i user name 






Q add pen 


) i user name 
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J i user name 






Q add pen 


)i user name 
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user name 






Q add pen 
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Q add pen 


)i user name 













Figure 14. Pen registration - local users page 
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3.2.4 Authorize User on Printer 



iS^S^^ t0 additi ° nal NCtpage Printers - °™* authorized t0 « a par- 
ticular printer, the user may interact with the printer using any pen linked to the user 

submit 
(unknown user) 




Figure 15. User authorization user interface flow 

^«l e I 0m J' SUbmitted> ^ namC information « matched against the global user list 

^iS^T^' 0311 * r tCred> SUCh 35 jUSt 3 firet name <* a n^ame. If the 
wIS ,l < T mb « uous - the VStem generates a list of matching users (Figure 17) 
with an <authonze user> button next to each. S ' 
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Wton on the MP PXS- »—« * '«< ° f £"? °" *2t 



available to all users, 



work (Figure 18), ^■^^ ^ who elected to appear. 



„> cabled, the user authorization form must be authorized by an admin- 

ZZS^tt^L* *• authorization form in *■ appropnate P 



The user authorization user 



interface flow is illustrated in Figure 15. 




Figure 16. User authorization page 
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page# of# 



First Name T fir 3t name ' 
Nickname , r nickname " ' 
Family Name iFamify'name' 



— r — — — 

i Initials i initials 



(_auth user") [ uej " n Sme" 

( auth user^ ; use^nlme = = :=:: = = = = = = : 

(auth usgr^r^er'nam^ = = =: = = = = = = = : 

C auth u&er ^) |"u5er"name =======: 

C auth u ffO [ user~nam~e~ = = = :: = = = = = = = 

C auth U5gr ^ \ uelr'nlme' -========== 

C auth U5gr ^ ; r uggr"name ======== 

C auth "gcQ i'user'namfl = = = = = = = = 

(^auth uggr^ i r uscr"namc = = = = = = = 

^ uth user"^ i" tTsgr'na me = = = = = = = = ; 

C auth usg O ;"u&er"nam g " - = = :r:::: = = = = = : 

(auth ueer") ^ueer'name zzz - = -- = = : 
C auth ^er^ iuser^arne = = = = = = = = 1 

C auth U5e Q [ u^er~name = = = = = = = = 

(juth ueer^) T u 5 er"nam e " - Z - :::: = = = = = = = 



(_auth U5er") , r u 5 ; r " n ^ e " " 



' user name " = = = = = = = = = = = : 



Figure 17. User authorization - matching 



users page 
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Authorize Netpage Deer on Printer: [ page #of#\ 

Global Ueer Uet 



Q auth user ^ \ user name 
Q auth user^ i user name 
^auth user^ i user name 
^ auth user user name 
Q auth user ^ T user name 
Q auth user ^ i user name 
Q auth user user name 
Q auth user ^ i user name 
^ auth user^ t user name 
^ auth user ^ i user name 
^ auth user user name 
Q auth user user name 
^auth user ^ i user name 
Q auth user user name 
^ auth user user name 
Q auth user ^ i user name 
Q auth user ^ i user name 
Q auth user user name 
Q auth user user name 
Q auth user user name 
Q auth user ^ * user name 
^auth user ^ i user name 
Q auth user user name 



Figure 18. User authorization - global users page 
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3.2.5 



Authorize Terminal on Printer 



The <authorize terminal on printer> button on the help page produces a terminal authori- 
zation token. The token is printed with information which allows the user of the Web ter- 
minal to register the Web terminal with the Netpage Network, allowing it to print to the 
Netpage Printer identified by the token. 

An administrator may revoke a terminal's authorization at any time. The <authorize termi- 
nal on printer> button is also only available to administrators. 




Figure 19. Terminal authorization user interface flow 
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4 Electronic Mail 



Netpage electronic mail (e-mail) provides a messaging service between Netpage users. It 
ZST message exchange with Internet e-mail users, and by extension, users of 
^^y^bmcoaoM with the Internet, such as corporate e-ma.l systems. 

Each Netpage user has a unique id within the Netpage System, and is also known to the 
system by Lir name, which may or may not be unique. Netpage e-rna.1 » usually 
adSeied by selecting a name from a list, for example from the globa list of Netpage 
^r from a particular user's list of contacts. The user's nickname or ahas helps disam- 
biguate similar names. A Netpage user usually doesn't have to know or specify another 
Netpage user's unique id. 

When a Netpage user wants to send e-mail to an Internet user, they must specify an Inter- 
net e-mail SdLs. Similarly, when an Internet user wants to send e-ma.l to a Netpage 
user! they must specify the Netpage e-mail address. A Netpage e-ma.l address takes the 
form <userid>@ netpage . net. 

E-mail is a core service of the Netpage System. 



4.1 E-mail Object Model 

4.1.1 E-mail User 

The e-mail object model revolves around an e-mail user. An e-mail user is either a 
Netpage user or an Internet user. 

The e-mail user class diagram is shown in Figure 20. 



e-mail 
user 



3 



I 




user , 


Internet 
user 




name 

e-mail addr 



Figure 20. E-mail user class diagram 



4.1.2 E-mail 



The e-mail itself consists of a number of pages. Each page "r^^^f-^. 
page structure is logical because the e-mail is delivered in the same form that it is com 
posed, and it is composed by the sender page by page. 

Each page contains digital ink, together with any number of attachments. An attachment is 
printed! its point of insertion, and may overflow onto the following page(s). 
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The sender of the e-mail is an e-mail user, as are any number of recipients and copy recip- 
ients (CCs). Blind copy recipients (BCCs) are not modelled here for clarity, but can obvi- 
ously be trivially accommodated. 

The e-mail has a explicit subject which is always converted from digital ink to text to sup- 
port interoperation with e-mail systems which don't directly support digital ink, such as 
e-mail systems on the Internet, and to streamline the presentation of mailbox contents 
within the Netpage System itself 

The e-mail has a high priority flag which allows the both sender and the recipients to con- 
trol the timeliness of its delivery. 



The e-mail class diagram is shown in Figure 21. 



recipient 



e-mail « - 
user J" 
— — — — ^ 
I sender 



e-mail 



copy recipient 



subject 
high priority 
date & time 



1 



page 




attachment 




content 


content 



Figure 21. E-mail class diagram 

4.1.3 Mailbox 

Incoming e-mails may be accumulated in the user's mailbox, printed on the user's default 
printer, incorporated into the user's daily newspaper, or any combination of these. The 
user can select, for example, to print high-priority e-mails immediately on receipt but to 
hold low-priority e-mails. 



Netpage J 


mailbox 


user J 







e-mail 
folder 


r 

• * 1 


1 

k 


name 

delivery opts 



e-mail 



Figure 22. Mailbox class diagram 



Confidential 



7 September 1999 



23 



Sifverbrook Research 



Netpage Applications 



draft v0.1 



The user may create any number of named folders within the mailbox, and either manually 
copy and move received e-mails between folders, or associate a folder with one or more 
e-mail contacts (including e-mail groups) to have e-mail received from those contacts 
automatically placed in the folder. E-mail received from contacts not associated with a 
folder is placed in a predefined "inbox" folder. All e-mail sent by the user is placed in a 
predefined "sent e-mail" folder for future reference. 

Each folder has three delivery options: "print all e-mail", "print high-priority e-mail", and 
"delete e-mail once printed". If a print option is selected, e-mail messages with the corre- 
sponding priority are printed on the user's default printer immediately on receipt. If the 
delete option is selected, e-mail messages are deleted from the e-mail folder once printed. 
Otherwise e-mail messages are held indefinitely in the e-mail folder, i.e. until manually 
deleted by the user. 



The mailbox class diagram is shown in Figure 22. 



4,1.4 Contact List 

Each user has a list of contacts. The contact list provides a more convenient basis for 
selecting e-mail recipients than the global list of users, particularly since most user's con- 
tact lists will fit on a single double-sided printed page. The contact list also provides a 
basis for ignoring unsolicited e-mail. A privacy option allows a user to ignore e-mail not 
sent by a member of the contact list. 

A user may create any number of contact groups within the contact list, and treat a group 
as a single contact for the purposes of addressing outgoing e-mail and controlling the 
delivery of incoming e-mail. 

Groups may themselves contain groups, and both individual contacts and groups may be 
members of multiple groups as well as the top-level contact list itself. 



The contact list class diagram is shown in Figure 23. 
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Figure 23. Contact list class diagram 
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4.1 .5 Barred User List 

Rather than accepting e-mail only from known contacts, a user may choose to bar individ- 
ual users. The barred user list records individuals from which the user refuses to accept 
e-mail. 

The barred user list class diagram is shown in Figure 24. 
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Figure 24. Barred user list class diagram 

4.2 E-mail User Interface 

4.2.1 Send E-mail 

E-mail is sent using the outgoing e-mail form (see Figures 27 and 28). The e-mail form is 
always printed with the sender's name already specified, since the sender's identity is 
known from the pen used to request the e-mail form. If the e-mail form is requested by 
pressing a user-specific <e-mail> button on some page, then the e-mail form is printed 
with the recipient's name already specified. On the other hand, if the e-mail form is 
requested from the help page, then the recipient is unknown and is left blank on the form. 
The user must specify at least one recipient before the e-mail can be sent. 

The user can also pre-address an e-mail form by pressing the <e-mail to contacts> button 
on the help page. This elicits an add recipients form (Figure 29), which lists the user's 
contacts. Each contact has a <To> and a <CC> checkbox as well as an <e-mail> button. 
The e-mail button elicits an e-mail form addressed to that user. The <e-mail selected> but- 
ton at the bottom of the page elicits an e-mail addressed to all the users whose <To> or 
<CC> checkboxes have been checked. 

The e-mail form initially consists of a double-sided page. The front (Figure 27) contains 
fields for the names of recipients and copy recipients, for the subject, and for the body of 
the e-mail. The back (Figure 28) contains a field for continuing the body of the e-mail. 
Any recipient names (or addresses) written by hand are converted from digital ink to text 
for lookup purposes. The subject is also converted, for presentation purposes, as discussed 
earlier. The body is retained as digital ink, to allow handwritten text and diagrams etc. to 
be delivered in a uniform and expressive manner. 

The <add page> button at the bottom of every page of the e-mail form adds another dou- 
ble-sided page to the e-mail form. Only the additional page is printed, not the entire form, 
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but the additional page is logically linked to the original e-mail. The <discard page> but- 
ton at the bottom of every page discards the corresponding page from the e-mail (but not 
both sides of the double-sided page). The entire e-mail is reprinted with the discarded page 
removed and subsequent pages, if any, moved to close the gap. A blank page added to 
make the page count even, if necessary. 

Each printed e-mail form corresponds to a separate e-mail instance, the uniqueness of 
which is indicated by the sender's name, date and time printed at the top of every page. 
Once an e-mail has been sent, it can't be sent again. A copy, however, can be easily made, 
edited, and sent. The standard <print> button on every page of the e-mail form prints 
another copy of the e-mail form, corresponding to a new e-mail instance. Both the original 
and the copy can be edited further and sent independently. 



e-mail 
contacts 




bar 




Figure 25. E-mail user interface flow 

Text in the <recipients>, <copy recipients and <subject> can be struck out with the pen 
to remove recipients, subject text, etc. The <print> button produces a copy of the e-mail 
form with the struck-out text removed. 

The <attach> button at the bottom of every page attaches the current selection at the cur- 
rent end of the e-mail body. The entire e-mail is reprinted with the attachment included. 
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Additional pages are automatically added to the e-mail to accommodate the attachment 
The attachment can consist of anything which can be selected on any Netpage. 

^t^Urr? 1 ' 5 ' *Tt adjaCe " t t0 fte <re «Pi«"s> and <copy recipients* fields at 

tt < P wZVtVZ t mail fonn elidtS m fo ™ <?*S™ 29), wi£ 

the <jmbject> field reflecting the subject of the e-mail form. The <e-mail> and i ma U 
selected* buttons on the add recipients form elicits a copy of the e-mail form wTth the 
additional recipients and copy recipients added. 

The <send> button at the bottom of every page sends the entire e-mail. If the name of any 
recipient .s unknown to the system, then the e-maii form is reprinted with the offending 
name printed in red, together with an error message indicating the problem. 

l f i£ C ^ ^ reCipient * an,bi * uou * *«* a list of matching users is printed, each 
with a checkbox allowing it to be selected. The <e-mail> button at the bottom of the form 
reprints the e-mail form with the recipient names suitably updated. 
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Figure 26. E-mail recipient exception user interface flow 

The overall e-mail user interface flow is illustrated in Figure 25. The e-mail recipient 
exception user interface flow is illustrated in Figure 26. 
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Figure 27. Outgoing e-mail first page 
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Figure 28. Outgoing e-mail second or subsequent page 
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Figure 29. Add recipients page 
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4.2.2 Receive E-mail 

E-mail is received in the form of an incoming e-mail document (Figures 30 and 31), 
which has the same page structure and content as the corresponding outgoing e-mail form' 

The <reply> button at the bottom of every page of the e-mail document produces an out- 
going e-mail form (Figures 27 and 28) addressed to the sender of the incoming e-mail, and 
with the subject reflecting the subject of the incoming e-mail, but with "In reply to:" added 
as a prefix. 

The <reply to all> button produces an outgoing e-mail form addressed to the sender of the 
incoming e-mail, as well as to all of its recipients and copy recipients. 

The <forward> button produces an outgoing e-mail form with no recir ent, and with the 
subject reflecting the subject of the incoming e-mail, but with "Forwarded:" added as a 
prefix. The body of the incoming e-mail is also copied to the body of the outgoing e-mail. 

The <forward to contacts> creates, but doesn't print, an outgoing e-mail in the same way 
as the <forward> button, and then implicitly invokes the <add recipients> command on it. 
This elicits an add recipients form in the usual way (Figure 29), with the <subject> field 
reflecting the subject of the forwarded e-mail. 

The <add to contacts> button adds the sender to the recipient's list of contacts and pro- 
duces an edit contacts form reflecting the updated contact list. Contact list editing is 
described in more detail in Section 4.2.3 on page 34. 

The <bar> button adds the sender to the recipient's list of barred users and produces an 
edit barred users form reflecting the updated barred user list. Barred user list editing is 
described in more detail in Section 4.2.5 on page 43. 
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Figure 30. Incoming e-mail first page 
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Figure 31. Incoming e-mail second or subsequent page 
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4.2.3 Edit Contact List 

The contact list is edited using the edit contacts form (Figure 33). Because the structure of 
an individual contact group is the same as die structure of the top-level contact list, the 
same form is used to edit a contact group. The form is obtained by pressing the <edit con- 
tact list> button on the help page. It is also printed whenever a contact is added to the con- 
tact list, for example when the <add to contacts> button is pressed on an incoming e-mail 
to add the sender to the contact list. 

Each entry on the contact list form shows the name on the contact, and the current e-mail 
folder in which e-mail from the contact is placed. Each entry has a checkbox which allows 
the contact to be selected, an <info> button which elicits a page of information about the 
user (Figure 44), and a <set mailbox^ button which allows the e-mail folder associated 
with the contact to be changed via the set e-mail folder form (Figure 35). 

The <delete selected> button at the bottom of the form deletes the selected contacts from 
the contact list (or contact group). The form is reprinted with the deleted contacts 
removed. 

The <copy to group> and <move to group> buttons at the bottom of the form allows the 
selected contacts to be copied and moved to a particular group via the copy contacts form 
(Figure 34). 

The contact list editing user interface flow is illustrated in Figure 32. 




Figure 32. Edit contact [list,group] user interface flow 



Confidential 



7 September 1999 



34 



Silverbrook Research Netpage Applications 



draft v0.1 



Bdjt_ Contact _ [Liet, GroupJ 
\ group contact name 



i page# oft 



Select 

□ ( info ~") i contact name 

C ^ofder^ 3 ' e " mail fairer name 
Cj^ info ^ i contact name 

C ^folder^'p ! e " mai ' "bolder name 



( info ^ contact name 

i^5%* n Y .^maW fol^r'name""" ' 

m info ^ contact name 

C *%?der a " ^ -mall bolder name 



info ^ t contact name 

(6£t e-mail N t r ~ " 7], "vr , ~~~ 
folder J . e ~ mai1 folder name 

[^J info ^ contact name 

C ^ e fo?der an ^) I e_mai ' "folder name 



□ (^ info ~) i contact name 

C ^foldeT 11 0 [ foTder^name" 
[jj info T contact name 

C *%?der a " ) [ e-mail^oTdername] 



name 



C^J info ^ T contact 

folder J . e ~ ma " folder name 
C ' n ^° ^ 1 corrt act name 

folder J. e ~ ma " folder name 



(delete selected) ("copy to groujT^move to group) 



Figure 33. Edit contacts page 

The copy (move) contacts form lists all of the groups in the user's contact list, each with a 
<copy to> (<move to>) button which copies (moves) the selected contacts to the specified 
group. When a <copy to> (<move to>) button is pressed, an edit contacts form is printed 
which shows the updated membership of the destination group. 
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The copy (move) contacts form provides a <new group name> field with an associated 
<copy to new> (<move to new>) button. This allows a new group to be simultaneously 
created and selected as the destination for the copy or move. 
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Figure 34. Copy contacts first page 

The set e-mail folder form lists all of the folders in the user's mailbox, each with a <set> 
button which sets the folder as the contact's e-mail folder. When the <set> button is 
pressed, the edit contacts form is re-printed to reflect the new folder associated with the 
contact. 
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The set e-mail folder form provides a <new e-mail folder name> field with an associated 
<set new> button. This allows a new folder to be simultaneously created and selected as 
the contact s e-mail folder. The new folder has an associated set of checkboxes which 
allow the folder s e-mail delivery options to be specified. 
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Figure 35. Set e-mail folder first page 
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4.2.4 List Mailbox 

The contents of the user's mailbox are listed using the mailbox form (Figure 37) and the 
e-mail folder form (Figure 38). The mailbox form lists all of the user's e-mail folders, 
each with a set of checkboxes which reflect the folder's e-mail delivery options and allow 
the delivery options to be changed. Each folder entry also has a checkbox which allows it 
to be selected. The <count> next to each folder name indicates the number of un-printed 
(i.e. un-read) e-mails in the folder. 

The <delete selected> button at the bottom of the form deletes all selected folders from the 
mailbox. The mailbox form is re-printed with the deleted folders removed. 

The <update options> button at the bottom of the form applies any changes made via the 
checkboxes to me folders' delivery options. 

Each folder entry also has <list> button which lists the contents of the folder via the e-mail 
folder form (Figure 38). 

The mailbox listing user interface flow is illustrated in Figure 36. 



delete selected/ 
update options 




< list ^ — 


mailbox 


Pi 


I I 



delete selected 



[copy, move] to/ 
[copy, move] to new 




Figure 36. List mailbox user interface flow 

The e-mail folder form lists all of the e-mails in the folder. Each single-line e-mail entry 
shows the sender of the e-mail, the subject of the e-mail, and the date and time the e-mail 
was received. The list can be sorted by sender, subject, or date and time. Each column 
which is not the current sort column has a <sort> button which allows the list to be sorted 
by that column. When a <sort> button is pressed the e-mail folder is sorted by the selected 
column and the form is re-printed. 
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Figure 37. Mailbox page 

Where an e-mail is a reply to another e-mail, the subject of the replying e-mail is indented 
relative to the subject of the e-mail to which it is replying. Thus each thread of a discus- 
sion is clearly visible. Entries for e-mails which have never been printed are printed in 
bold to draw the user's attention. 
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Each e-mail entry has a checkbox which allows it to be selected, as well as a print button 
which allows the entire e-mail to be printed in the form of an Incoming E-mail (Figures 30 
and 31). 

The <delete selected> button at the bottom of the form deletes the currently selected 
e-mails. The e-mail folder form is reprinted with the deleted e-mails removed. 
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Figure 38. E-mail folder page 
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The <copy selected> and <move selected> buttons at the bottom of the e-mail folder form 
allow the currently selected e-mails to be copied or moved to a different e-mail folder via 
the copy e-mail form (Figure 39). 
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Figure 39. Copy e-mail first page 

The copy (move) e-mail form lists ail of the folders in the user's mailbox, each with a 
<copy to> (<move to>) button which copies (moves) the selected e-mails to the specified 
folder. When a <copy to> (<move to>) button is pressed, an e-mail folder form is printed 
which shows the updated contents of the destination folder. 



Confidential 



7 September 1999 



41 



Sitvertorook Research 



Netpage Applications 



drattvO.1 



The copy (move) e-mail form provides a <new e-mail folder name> field with an associ- 
ated <copy to new> (<move to new>) button. This allows a new folder to be simulta- 
neously created and selected as the destination for the copy or move. The new folder has 
an associated set of checkboxes which allow the folder's e-mail delivery options to be 
specified. 
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4.2.5 Edit Barred User List 

The barred user list is edited via the edit barred users form (Figure 41). The form is 
obtained by pressing the <edit barred user list> button on the help page. It is also printed 
whenever a user is barred, for example when the <bar> button is pressed on an incoming 
e-mail to add the sender to the barred user list. 

Hie form lists all of the users in the user's barred user list. Each has a checkbox which 
allows it to be selected. 



The <unbar selected> button at the bottom of the form deletes the selected users from the 
barred user list. The form is re-printed with the deleted users removed. When a user is 
deleted from the list that user no longer barred. 

The barred user editing user interface flow is illustrated in Figure 40. 
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Figure 41. Edit barred users page 
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4.2.6 Global User Directory 



The global user directory, since it is large, is navigated via a directory index (as described 
in Section 2 on page 6). It is obtained by pressing the <global user directory> button on 
the help page. 

The global user directory page (Figure 43) contains an alphabetical list, by family name 
of users m the name range covered by the page. Each entry has three associated buttons' 
The <mfo> button produces a user information page (Figure 44), the <e-mail> button 

tte^r^° mg e " maU ?™ (FigUreS 27 3,1(1 28 > addressed to me corresponding 
user, and the <add to contacts> button adds the user to the user's contact list and prints the 
updated contact list (Figure 33). v 

The global user directory page also contains the standard index navigation buttons. 

The global user directory user interface flow is illustrated in Figure 42. The index user 
interface flow and associated page layouts are as described in Section 2 on page 6. 





Figure 42. Global user directory user interface flow 

The user information page (Figure 44) contains the user's contact details as provided dur- 
ing user registration, subject to the user's privacy preferences. It also contains <e-mail> 
and.<add to contacts> buttons which work in the usual way. 

The internet e-rhail address> is only included if the user information page is printed via 
the contact list for an Internet contact (as opposed to a Netpage contact) 
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Figure 43. Global user directory page 
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Figure 44. User information page 
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4.2.7 Business Card 

A Netpage business card (Figure 46) serves a dual purpose. While it conveys the user's 
contact details in the usual way, it also acts as an e-mail authorization token. When the 
recipient of the card presses the <add to contacts> button on the card, the owner of the 
card is added to the recipient's contact list in the usual way, but the recipient is also added 
to the owner's contact list, authorizing the recipient to send e-mail to the card owner, 
should the card owner only accept e-mail from known contacts. The token only allows the 
recipient to be added to the owner's contact list once. 

The card also contains an <e-mail> button which generates an outgoing e-mail form 
addressed to the card owner in the usual way. 

The business card user interface flow is illustrated in Figure 45. 
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Figure 45. Business card user interface flow 






i [title] [first name] [initials] [nickname] [family name] i 


Q e-maif 


) 


i [street address 1] » 


S Add to 
\^ contacts 


) 


i [street address 2] i 






»" [city] [state] [Zip 7 Code] t 






i [country] i 






i [work phone: work phone number] i 






i [mobile phone: mobile phone number] ■ 






i [home phone: home phojie number] t 







Figure 46. Business card 

Since normal Netpage Printers don't support business card paper stock, Netpage business 
cards are provided by a service bureau on request. The business card request form (Fig- 
ure 48) allows the user to specify which contact details to include on the business card, an 
optional background texture, and the number of cards required. Once the request is sub- 
mitted, the cards are automatically printed by the bureau, delivered by mail to the user's 
address, and the small cost charged to the user's Netpage account. 
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The business card request user interface flow is illustrated in Figure 47. 
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Figure 47. Business card request user interface flow 
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Figure 48. Business card request page 
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4.2.8 Add Internet Contact 

An Internet e-mail user can be added to a user's contact list using the Internet contact 
registration form (Figure 50). Since an Internet user is not otherwise known to the 
Netpage System, the form allows full name details to be specified, in addition to the Inter- 
net user's e-mail address. 

The Internet contact registration user interface flow is illustrated in Figure 49. 




Figure 49. Internet contact registration user interface flow 
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Figure 50. Internet contact registration page 
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Tlie Netpage System provides efficient mechanisms for merchants to offer goods and ser- 
vices to customers, and for customers to select and pay for those goods and services. 

A customer can order directly from a catalog browsed and printed dynamically via 
Netpage, as well as from a preprinted catalog delivered by traditional means. 

The customer's dynamic signature, in combination with the customer's uniquely identified 
pen, authenticates the purchasing transaction in a way which is impossible to forge. If the 
customer chooses to use the Secure Electronic Transaction (SET) payment mechanism 
built into the Netpage System, then the customer's payment card details are never revealed 
to the merchant, ensuring that card details can neither be accidentally nor maliciously 
compromised. 

The purchasing mechanisms described in this section are generic, and apply to the pur- 
chasing of myriad kinds of goods and services. 



5.1 Purchasing Object Model 

The purchasing object model revolves around merchants and customers. 

Each merchant has a globally unique identifier, as well as a name and other details. Each 
customer is related to a particular merchant, and has an identifier which is unique within 
the scope of the particular merchant. Each customer represents a particular Netpage user 
to the merchant. A Netpage user, on the other hand, can be the customer of any number of 
merchants. 

Each merchant offers a range of products for sale, typically presented in the form of an 
organized catalog. Any Netpage user can browse the merchant's catalog, but the user must 
become an explicit customer of the merchant before being able to complete an order with 
the merchant. 
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The merchant class diagram is shown in Figure 51, while the customer class diagram is 
shown in Figure 52. 
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Figure 51. Merchant class diagram 

The name and description of a customer derives from the details of the corresponding 
Netpage user. 

Each customer has a history of payment methods and shipping addresses with the mer- 
chant. The most recent of each is recorded and used as the default on any new order. 

Each customer has an account with the merchant which records the net balance of all 
invoices and received payments. Account payments, i.e. payments not associated with a 
particular invoice, are associated directly with the customer account. 
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Figure 52. Customer class diagram 
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Each customer has a history of orders, each in a particular state of completion as reflected 
by its status. The order class diagram is shown in Figure . 

Each order is uniquely identified within the scope of the merchant. 

Each order has a status which indicates whether the order is pending (i.e. not yet submit- 
ted) active, partially or fully shipped, cancelled or completed. An order is not completed 
until full payment is received. 

Each order consists of a number of order items, each of which specifies the quantity of a 
particular product offered by the merchant Each order item also includes a backorder 
quantity and a quantity shipped. The backorder quantity is used to register a claim on 
future stock when there is insufficient current stock to fully satisfy the order item The 
quantity shipped is used to record the cumulative quantity actually shipped. 
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Figure 53. Order class diagram 

The most common of the many possible payment methods are shown in the payment 
method class diagram in Figure 54. The set of payment methods supported by a particular 
merchant will be specific to that merchant, and may be different for different customers of 
the merchant depending on their credit ratings etc. 
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When the Netpage account payment method is used, the user's Netpage account is deb- 
ited, and the transaction appears on the user's Netpage account statement. 

When the customer account payment method is used, the user's customer account is deb- 
ited, and the user is invoiced for payment. 

When the pro forma invoice payment method is used, a pro forma invoice is issued 
requesting pre-payment of the order. When payment is received, the goods are shipped. 

When the cash on delivery payment method is used, payment is expected when the goods 
are delivered. 

When the SET payment card payment method is used, the corresponding SET payment 
card linked to the user is used to make payment according to the normal SET protocol. 

When the payment card payment method is used, the specified payment card is used to 
make payment according to the normal protocol between the merchant and their acquiring 
bank or institution which handles the particular payment card type. 

Invoice and pro forma invoice payments are normally made with a check or money order. 
Cash on delivery payments are normally made with a check or cash. 
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Figure 54. Payment method class diagram 

The set of shipping methods which applies to a particular order depends on whether the 
order's shipping address is domestic or international with respect to the location of the 
merchant's warehouse. Typical domestic shipping methods include standard shipping, sec- 
ond day air, and next day air. Typical international shipping methods include standard 
shipping, airmail, and international priority. 
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The most common shipping methods are shown in the shipping method class diagram 
Figure 55. 
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Figure 55. Shipping method class diagram 
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5.2 Purchasing User Interface 

The status of the order determines the allowable set of operations on the order. While the 
order is pending, the user can browse the merchant's catalog and add items to the shopping 
cart which represents the order. After the order is submitted, the user can still amend the 
payment method, shipping address and shipping method until the order is fully shipped. A 
change obviously only applies to items not yet shipped when the change is made. The user 
can delete order items or change the quantity ordered until the items are actually shipped. 
Quantity increases are subject to availability and payment approval. 
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Figure 56. Online purchasing user interface flow 
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The overall purchasing user interface flow is illustrated in Figure 56. 

5.2.1 Locate Merchant 

A merchant can be located by browsing or searching the global Netpage directory or the 
user's own bookmarks. A merchant may also be encountered in the form of an advertise- 
ment in a Netpage publication. Both a directory entry and an advertisement typically link 
to the merchant's main page. This in turn links to the merchant's product catalog If the 
user already has a copy of the merchant's main page from a previous encounter then the 
catalog is immediately available. 

5.2.2 Browse Catalog 

A small product catalog is typically organized into - set of categories. The main cataloo 
page simply lists the categories, and each category page lists all of the products in the cat- 
egory. This is indicated in the user interface flow in Figure 56. 

If the product catalog is large, then it may still be organized into categories, but it may be 
impractical to print the entire contents of a category when a user wishes to browse the cat- 
egory. Instead the directory navigation techniques described in Section 2 can be used A 
catalog search w.U often be specific to the kinds of products represented in the catalog.' 

5.2.3 Order Item 

Many applications involve the user maintaining a collection of items. In the screen-based 
version of the application, the user's collection is typically shown every time an item is 
added or removed. The user therefore receives immediate feedback when the collection 
changes. The collection may reflect an e-mail recipient list, a shopping cart, etc. 

In the Netpage version of the application, it is less practical to re-print the collection every 
time it changes. Item deletions and quantity changes can be marked up visibly and so do 
not necessarily require immediate re-printing. Item insertions, however, are more prob- 
lematic. In some cases the entire source list can be used as the input form, allowing it to be 
marked up visibly. This may be particularly apt if the source list already represents a 
user-specific subset of the complete source list, e.g. last week's shopping list rather than 
the grocery store's complete range. There will be cases, however, where the user will pri- 
marily be making selections from a complete catalog. The catalog may even be many hun- 
dreds of pages long, offset printed, and delivered in the mail. Since it is intended for 
multiple use, it is not suitable for visible markup. 

One way to order via a large catalog is to print intermediate product-specific pages Each 
catalog entry has both an <info> and an <buy> button. The <info> button elicits a 
full-page description of the product with a quantity field which, if filled in, adds the prod- 
uct to the shopping cart and provides a visible record of the item order. This avoids having 
to print the contents of the shopping cart every time an item is added to it The <buy> but- 
ton elicits a similar full-page description of the product but automatically adds it to the 
shopping cart. It contains a quantity field, already filled in with the quantity ordered by 
default, which can be used to vary the quantity ordered. 

Depending on the nature of the order, it may be practical to also list the contents of the 
shopping cart on the product-specific page. However, it is the fact that the product page 
gives product-specific information that is of primary value to the user. 
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The product page is visibly linked to the order itself because it is tagged with the name of 
the current user, the order transaction number, and the order date and time. 

5.2.4 Complete Order 

The shopping cart represents the contents of the current order. The shopping cart is acces- 
sible from any merchant page, whether the page is part of the current order form or not. 
The shopping cart provides a convenient place to review the order and make final changes. 

The checkout is also accessible from any merchant page. It provides a place to specify 
shipping and payment information, and finally to confirm the order. 

The checkout form is broken up into five sections: shipping address, shipping method, 
payment method, order items, and order confirmation. Sections have default selections 
based on the user's most recent behavior. 

The order confirmation section summarizes the order and captures the user's signature. It 
shows the current shipping address, shipping method, payment method, and order total. 

Any change the user makes to the order on the checkout form is reflected on the form, 
since the change is made with the inking pen. It is not reflected, however, in the order 
summary in the order confirmation section. To produce a consistent checkout form, the 
user can simply press the <update> button at the bottom of the form after making a num- 
ber of changes. An updated checkout form is immediately printed. 

The <submit> button, when pressed, submits the order. Any handwritten change to any 
item information page, shopping cart page, or checkout page which is part of the order 
form is automatically interpreted and applied to the order. The order receipt, printed in 
response to the order submission, reflects the actual contents of the order. 

The checkout form consists of a header (Figure 57), a section for selecting a previously 
used shipping address or specifying a new address (Figure 58), a section for selecting a 
shipping method (Figure 59), a section for selecting a previously used payment method or 
specifying a new payment card (Figure 60), a section for reviewing the list of order items 
and making last-minute changes (Figure 61), a section for signing the order to confirm 
payment (Figure 62), and a footer which contains the <update> and <submit> buttons. 

The printed checkout form will vary in length depending on the number of previously 
used shipping addresses and payment cards, and the number of items in the order. In many 
cases it will fit conveniently on two pages printed on a single sheet of paper. 

The order receipt lists the items ordered and summarizes the order parameters in much the 
same way as the order confirmation section of the checkout form (Figure 62). 




Figure 57. Checkout page header 
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Figure 58. Checkout page shipping address 
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Figure 59. Checkout page shipping method 
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Figure 60. Checkout page payment method 
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Figure 61. Checkout page item list 
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(5) Confirm Order 
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Figure 62. Checkout page order confirmation 
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Figure 63. Checkout page footer 



5.2.5 Edit Account 



Users can edit their customer details maintained by the merchant, including their list of 
shipping addresses and their list of payment methods. They can also print their order list, 
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and details of individual orders. They can edit any order which has not been fully shipped, 
as described earlier. 

The order list gives the status for each order. Pressing the <info> button associated with 
each order yields a copy of the order receipt, but with an updated status for each order 
item The status of an order item derives from the status of the order it is part, as well as 
the presence of shipment items and backorder items associated with the order item. 

5.2.6 Edit Order 

The order receipt allows the quantities of individual order items which are still active to be 
altered. Once alterations are made, the user must press the <submit> button. An updated 
receipt is produced. 

To edit order parameters, the user can press the <edit> button on the order receipt. This 
produces an order editing form which is similar in structure to the checkout form. Once 
alterations are made, the user must press the <submit> button. An updated receipt is pro- 

duced 

5.2.7 Receive Shipment 

The shipment is accompanied by payment receipt, or, if the payment method is "cash on 
delivery" an invoice which allows the user to pay the delivery person by traditional means 
(e 2 cash check, or payment card not processed through Netpage), or using a Netpage 
payment method listed on the form, simply by marking the appropriate payment method 
and signing the form with a Netpage pen. 
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1 Overview 

Netpage Printers are intended for use in domestic, commercial, corporate and hospitality 
environments. They all utilize pagewidth Memjet printheads [4], and are based on a sim- 
ple and reliable straight paper path, passing through a Memjet transfer roller printhead 
mechanism. In most cases the printed page is glued along one edge and adhered to the pre- 
vious page to form a final bound document that can be 1 page or 500 pages thick. They all 
interact with the wireless Netpage Pen. 

Netpage Printers come in various forms: wall-mounting, tabletop, portable, and pocket 
versions. 
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2 Wallprinter 

2.1 Wallprinter 

. A low-cost, wall-mounted, base model with a duplex VA" Memjet printhead array that 
accepts a full ream of US Letter paper in a vertical format as shown in Figures 1, 3 and 4. 
Paper is placed into a hinged top tray down onto a sprung platen and registered under edge 
guides before being closed. Figure 2 shows the access to the paper and ink cartridge. 

A replaceable cartridge containing cyan, magenta, yellow, and infrared inks and glue is 
also accessible when the tray is open. It connects via a series of self-sealing connectors to 
hoses that tranrrr.it ink and glue to their separate locations. The cartridge consists of a thin 
wail drawn aluminum casing that accommodates four ink bladders and a single glue blad- 
der into an injection molded connector base. This is a fully recyclable product with a 
capacity for printing and gluing 3000 pages (1500 sheets). It is protected from forgeries by 
use of an authentication chip [1,2]. 

When closed, a release mechanism allows the platen to push the paper against the pick-up 
roller assembly, where it is fed directly into the duplex Memjet printhead assembly. From 
there, the sheet passes a momentary action glue wheel with powered spike wheels, where 
it has glue applied to the vertical edge as it passes through. The glue wheel is capped when 
not in use and is operated by a powered camshaft. 

The printed sheet is fed down to a binding platen that operates with a closed steel wire 
loop system of pulleys, runners and a powered axle. This provides the necessary speed to 
push the sheet forward onto the rear of a previous sheet, glue/bind it and return to the 
home position to accept the next printed sheet in less than 2 seconds. A motorized paper 
tapper assembly aligns the sheets in a simultaneous operation. 

When a document is bound and finished, a powered exit hatch with a tamper sensor opens. 
Plastic foils work together with the hatch to direct the finished document to the back of the 
collection tray and feed any further documents into the tray without hitting existing ones. 
The collection tray is molded in clear polycarbonate and pulls out of its socket under a cer- 
tain loading. Access for removing documents is provided on three sides. 

The printer has a main PCB that accommodates all major circuitry components including 
external data jacks. A flex PCB runs from the main PCB to the paper tray and has three 
different color LEDs and a push button. The LEDs indicate "on", "ink out", "paper out", 
and "error". The push button is a "help" interface that prints out a simple instruction sheet 
and a compact features directory for the user. The unit is powered by an internal 
1 10V/220V power supply that is connected before wall-mounting. 
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Figure 2. Wallprinter paper and ink cartridge access 

The printer has several metal hangers on the rear, which locate into keyhole slots in a 
metal back plate that is securely fastened to a wall. When the printer has been connected, 
it is hung onto the back plate and fixed with a locking screw found under the paper tray. 

The Netpage Printers are fully customizable in finishes and color as the front moldings 
clip on to a core chassis and are easily removable. 
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2.2 Wallprinter Pro 

This printer is similar to Wallprinter in most respects, except that it has a duplex 1 1 " print- 
head assembly, which prints on US Letter paper in a landscape format (see Figures 5, 6 
and 7). This means a faster print time and binding time for each page, making for raster 
overall document delivery. 

Another difference is the location of the ink cartridge, which resides above the paper tray 
rather than down the side. Each page is glued along the horizontal edge by a full-length 
glue sponge, which is capped when not in use. Operation, printing, and document han- 
dling are identical to Wallprinter. 



Wallprinter Pro is fully customizable in finishes and color. 
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2.3 WALL-PRINTER PRO R 

This printer shares the same printing and binding configuration of US Letter landscape 
format as Wallprinter Pro. The main difference is the media delivery, which is in the form 
of a large print cartridge cartridge (see Figures 8, 9 and 10). This cartridge accommodates 
C, M, Y, and infrared inks and glue as well as a 1000 sheet capacity roll of paper. The car- 
tridge can be recharged at nominated outlets when required and it is protected from forger- 
ies by an authentication chip [1,2]. 

The printer has integral structural metalwork to support its weight and a ball bearing track 
for easy loading and removal. 

Wallprinter Pro R is fully customizable in finishes and color. 




Figure 8. Wallprinter Pro R, with print cartridge extracted 
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3 Tableprinter 

3.1 Tableprinter Pro 

This printer is a tabletop version of the Wallprinter Pro. Essentially, it is the same printer 
unit with a base plinth that adds extra functionality, such as USB, parallel port and a power 
socket (see Figure 1 1). 

Tableprinter Pro is fully customizable in finishes and color. 
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3.2 Tableprinter Pro R 

This printer is a tabletop version of the Wallprinter Pro R. Essentially, it is the same printer 
unit with a base plinth that adds extra functionality, such as USB, parallel port and a power 
socket (see Figure 12). 

Tableprinter Pro R is fully customizable in finishes and color. 




Figure 12. Tableprinter Pro R 
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4 Deskprinter 

4.1 Deskprinter Pro R 

The Deskprinter Pro R is a vertical format printer based around the large format print car- 
tridge (see Figures 13, 14, 15 and 16). This cartridge accommodates C, M, Y, Infrared inks 
and glue, as well as a 1000 page roll of paper. The print cartridge is lowered into the top of 
the unit through a latching hatch. When printing, the paper is fed through the printhead 
assembly where it is duplex printed and then ejected past a cutter which crops it into 
sheets. As the sheet passes the cutter, a glue wheel assembly glues along the long edge and 
powered spike rollers propel the sheet out into the binding area. 

The binding area consists of a bindii. r platen which operates with a closed steel wire ;**np 
system of pulleys, runners and a powered axle. This provides the necessary speed to ^;,h 
the glued sheet forward onto the rear of a previous sheet, glue/bind it and return to the 
home position to accept the next printed sheet in less than 2 seconds. A motorized p; *-er 
tapper assembly aligns the sheets in a simultaneous operation. 

When the document has been bound, a series of metal fingers at the top and bottom oTihe 
document rotate out of the way and the document is pushed into the out tray area. A pow- 
ered hatch opens and a motorized ejector assembly pushes the document through the exit 
slot of the unit. The hatch then closes onto the document ready for removal. Subservient 
documents are stacked up in a similar fashion. The user interface is identical to the o:her 
printers in the range. A large PCB contains all the processing and external interface com- 
ponents and connects to an internal 1 10V/220V power supply unit. 

Deskprinter Pro R is fully customizable in finishes and color. 
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Figure 14. Deskprinter Pro R, with print cartridge extracted 
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Figure 15. Deskprtnter Pro R plan 




Figure 16. Deskprinter Pro R elevation 
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5 Travel printer 



5.1 TRAVEL-PRINTER R 

The Travelprinter R is a small, lightweight, versatile and completely portable Netpage 
Printer (see Figures 17, 19, 20 and 21). It has in-built mobile network communication 
hardware and software, allowing it to download documents anywhere. Travelprinter also 
has communications ports for computer interface printing when required. 

The printer consists of a front and rear molding with a chassis to accommodate the major 
components including a lithium battery and an 8V2" duplex Memjet printhead assembly. 

A compact print cartridge cartridge with C, M, Y and infrared inks and paper is used in the 
printer, providing 50 US Letter pages or 100 A5 pages. It is protected from forgeries by an 
authentication chip. 




Figure 17. Travelprinter R 

A motorized guillotine assembly cuts the media between the cartridge and the printhead 
and motorized spike wheels eject the finished print out of the unit. A flex PCB runs from 
the main board to a segment LCD and two push buttons. The LCD shows signal strength, 
any errors, battery and number of pages left in the cartridge. The buttons allow the printer 
to either connect to the Netpage Network or to act as a stand-alone printer. A USB inter- 
face is provided on the side of the printer along with DC 3 V input. 
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Figure 18. Travelprinter R main and flex PCB, with buttons and segment LCD 




Figure 19. Travelprinter R, with print cartridge extracted 
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FC3 

Figure 21. Travelprinter plan and elevations 
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6 Microprinter 



6,1 Microprinter 

. The Microprinter is a small, versatile, pocket-size printer/camera (see Figures 22 and 23). 
It has built-in mobile network communication hardware and software, allowing it to link 
to the Netpage Network and fetch documents from anywhere. In addition, the product is 
economically configured and styled as a fully functional digital camera with the standard 
Classic, HDTV and Panoramic print formats for photography. 

The Microprinter accommodates a 4" (100mm) page-width print cartridge with C, M, Y 
and infrared ink plus 5.4 meters of paper. This means the user can single-sided print 41 
Netpages, 36 Classic, 30 Horizontal or , 18 Panoramic prints or any combination thereof 




Figure 22. Microprinter rear view with printing in progress (left), 
and front view with print cartridge extracted (right) 

The Microprinter is a fixed-lens camera with auto focus and digital photo enhancement 
capabilities, which allows the user to take sophisticated photos very simply and easily. A 
print burton allows the user to print and reprint a photo or Netpage. 

The Microprinter consists of two main front and rear moldings and a hatch. The main 
moldings accommodate the lens assembly, viewfinder optics and a rigid PCB. A flex PCB 
runs from the main board to the imaging chip, an LCD, the printhead assembly, the print- 
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head capping mechanism, a cutter assembly, the roll motor drive, various control switches 
and a CR2 battery. 

The Microprinter is fully customizable in finishes and color. 




Figure 23. Microprinter exploded view 
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7 Memjet-Based Printing 

A Memjet printhead produces 1600 dpi bi-level CMYK. On low-diffusion paper, each 
ejected drop forms an almost perfectly circular 22.5p.rn diameter dot. Dots are easily pro- 
duced in isolation, allowing dispersed-dot dithering to be exploited to its fullest Since the 
Memjet printhead is the width of the page and operates with a constant paper velocity, the 
four color planes are printed in perfect registration, allowing ideal dot-on-dot printing. 
Since there is consequently no spatial interaction between color planes, the same dither 
matrix is used for each color plane. Dot-on-dot printing minimizes 'muddying' of mid- 
tones caused by inter-color bleed. 

A page layout may contain a mixture of images, graphics and text. Continuous-tone (con- 
tone) images and graphics are reproduced using a stochastic dispersed-dot dither. Unlike a 
clustered-dot (or amplitude-modulated) dither, a dispersed-dot (or frequency-modulated) 
dither reproduces high spatial frequencies (i.e. image detail) almost to the limits of the dot 
resolution, while simultaneously reproducing lower spatial frequencies to their full color 
depth, when spatially integrated by the eye. A stochastic dither matrix is carefully 
designed to be free of objectionable low-frequency patterns when tiled across the image. 
As such its size typically exceeds the minimum size required to support a particular num- 
ber of intensity levels (e.g. 16x16x8 bits for 257 intensity levels). 

Human contrast sensitivity peaks at a spatial frequency of about 3 cycles per degree of 
visual field and then falls off logarithmically, decreasing by a factor of 100 beyond about 
40 cycles per degree and becoming immeasurable beyond 60 cycles per degree [7,8]. At a 
normal viewing distance of 12 inches (about 300mm), this translates roughly to 200-300 
cycles per inch (cpi) on the printed page, or 400-600 samples per inch according to 
Nyquist's theorem. 

In practice, contone resolution above about 300 ppi is of limited utility outside special 
applications such as medical imaging. Offset printing of magazines, for example, uses 
contone resolutions in the range 150 to 300 ppi. Higher resolutions contribute slightly to 
color error through the dither. 

Black text and graphics are reproduced directly using bi-level black dots, and are therefore 
not antialiased (i.e. low-pass filtered) before being printed. Text is therefore supersampled 
beyond the perceptual limits discussed above, to produce smoother edges when spatially 
integrated by the eye. Text resolution up to about 1200 dpi continues to contribute to per- 
ceived text sharpness (assuming low-diffusion paper, of course). 

The Netpage Printer uses a contone resolution of 267 ppi (i.e. 1600 dpi / 6), and a black 
text and graphics resolution of 800 dpi. 
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8 Document Data Flow 

Because of the page-width nature of the Memjet printhead, each page must be printed at a 
constant speed to avoid creating visible artifacts. This means that the printing speed can't 
be varied to match the input data rate. Document rasterization and document printing are 
therefore decoupled to ensure the printhead has a constant supply of data. A page is never 
printed until it is fully rasterized. This is achieved by storing a compressed version of each 
rasterized page image in memory. 

This decoupling also allows the RIP to run ahead of the printer when rasterizing simple 
pages, buying time to rasterize more complex pages. 

Because contone color images are reproduced by stochastic dithering, but black text and 
line graphics are reproduced directly using dots, the compressed page image format con- 
tains a separate foreground bi-level black layer and background contone color layer. The 
black layer is composited over the contone layer after the contone layer is dithered. 

Figure 24 shows the flow of a Netpage Printer document from network to printed page. 




Figure 24. Netpage Printer document data flow 

At 267 ppi, a Letter page of contone RGB or CMY data has a size of 19MB. Using lossy 
contone compression algorithms such as JPEG [9], contone images compress with a ratio 
up to 10:1 without noticeable loss of quality, giving a compressed page size of 1.9MB. 

At 800 dpi, a Letter page of bi-level data has a size of 7MB. Coherent data such as text 
compresses very well. Using lossless bi-level compression algorithms such as Group 4 
Facsimile [6], ten-point text compresses with a ratio of about 10: 1 (as discussed in Section 
1 1 .2. 1 .2), giving a compressed page size of 0.8MB. 

Once dithered, a page of CMY contone image data consists of 86MB of bi-level data. 
Using lossless bi-level compression algorithms on this data is pointless precisely because 
the optimal dither is stochastic - i.e. since it introduces hard-to-compress disorder. 
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The two-layer compressed page image format therefore exploits the relative strengths of 
lossy JPEG contone image compression and lossless bi-Ievel text compression. The for- 
mat is compact enough to be storage-efficient, and simple enough to allow straightforward 
real-time expansion during printing. 

Since text and images normally don't overlap, the normal worst-case page image size is 
1.9MB (i.e. image only), while the normal best-case page image size is 0.8MB (i.e. text 
only). The absolute worst-case page image size is 2.7MB (i.e. text over image). Assuming 
a quarter of an average page contains images, the average page image size is 1 . 1 MB. 
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9 Printer Controller 
Architecture 

The Netpage Printer controller consists of a controlling processor, a factory-selected net- 
work interface, a radio transceiver, dual raster image processor (RIP) DSPs, duplexed 
print engines, flash memory, and 64MB of DRAM, as illustrated in Figure 25. 




Figure 25. Basic printer controller architecture 

The controlling processor handles communication with the Internet and with local wire- 
less pens, controls the user interface (buttons and LEDs), controls the paper transport, han- 
dles ink cartridge authentication and ink monitoring, and feeds and synchronizes the RIP 
DSPs and print engines. It consists of a medium-performance general-purpose- micropro- 
cessor. 

The RIP DSPs rasterize and compress page descriptions to the Netpage Printer's com- 
pressed page format. Each print engine expands, dithers and prints page images to its asso- 
ciated Memjet printhead in real time (i.e. at 30 or 45 pages per minute). The duplexed 
print engines print both sides of the page simultaneously. 

The printer controller's flash memory holds the software for both the processor and the 
DSPs, as well as configuration data. This is copied to main memory at boot time. 

The processor, DSPs, print engines and digital transceiver components are integrated in a 
single ASIC. The MEMS and analog RF components are integrated in a separate MEMS 
chip, which is also used in the wireless pen. Additional pen-specific components in the 



Confidential 



7 September 1999 



29 



Sitverbrook Research 



Netpage Printer Design Description 



draft vO. 3 



MEMS chip are not used in the printer controller. The Internet network interface module is 
separate, since Netpage Printers allow the network connection to be factory-selected. 
Flash memory and the 2x256Mbit (64MB) DRAM is also off-chip. 

Various Internet network interface modules can be supported. Possibilities include a POTS 
modem, a Hybrid Fiber-Coax (HFC) cable modem, an ISDN modem, a DSL modem, a 
satellite transceiver, a current or next-generation cellular telephone transceiver, a wireless 
local loop (WLL) transceiver, etc. A Internet connection may already be available on the 
local network, in which case only a local network connection may be required. 

The printer controller optionally includes a local network connection, to allow the printer 
to be used from a directly-connected workstation or over a local-area network. Possibili- 
ties include lOBase-T and 100Base-T Ethernet, USB and USB 2.0, IEEE 1394 (Firewire), 
and various emerging home networking standards. 

The radio transceiver communicates in the unlicensed 900MHz band normally used by 
cordless telephones, and uses frequency hopping and collision detection to provide inter- 
ference-free communication. 

9-1 Detailed Document Data Flow 

The main processor receives and verifies the document's page layouts and page objects by 
Internet pointcast and multicast. It then runs the appropriate RIP software on the DSPs. 

The DSPs rasterize each page description and compress the rasterized page image. The 
main processor stores each compressed page image in memory. The simplest way to 
load-balance multiple DSPs is to let each DSP rasterize a separate page. The DSPs can 
always be kept busy since an arbitrary number of rasterized pages can, in general, be 
stored in memory. This strategy can lead to poor DSP utilization, however, when rasteriz- 
ing short documents. 

Watermark regions in the page description are rasterized to a contone-resolution bi-ievel 
bitmap which is losslessly compressed to negligible size and which forms part of the com- 
pressed page image. 

The infrared (IR) layer of the printed page contains encoded position tags at a density of 
about 25 per inch. Each tag encodes the page id, tag position, and control bits. Active 
areas and pressure-sensitive areas in the page description are rasterized to tag-resolution 
bi-Ievel bitmaps which do not require compression and which form part of the compressed 
page image. 

The main processor passes back-to-back page images to the duplexed print engines. Each 
print engine stores the compressed page image into its local memory, and starts the page 
expansion and printing pipeline. Page expansion and printing is pipelined because it is 
impractical to store a 1 14MB bi-Ievel CMY+IR page image in memory. 

The first stage of the pipeline expands the JPEG-compressed contone CMY layer, expands 
the Group 4 Fax-compressed bi-level watermark map, and expands the Group 4 Fax-com- 
pressed bi-Ievel black layer, all in parallel. The second stage dithers the contone CMY 
layer using the dither matrix selected by the watermark map, and composites the bi-level 
black layer over the resulting bi-Ievel CMY layer. Since there is no black ink used in the 
Netpage Printer, the black layer is composited with each of C, M and Y. In parallel with 
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this, the tag encoder generates and encodes the bi-level IR tag data. The last stage prints 
the bi-level CMY+IR data through the Memjet printhead via the printhead interface. 

9.2 Print Engine Architecture 

The print engine's page expansion and printing pipeline consists of a standard JPEG 
decoder, a standard Group 4 Fax decoder, a custom halftoner/compositor unit, a custom 
position tag encoder, and a custom interface to the Memjet printhead. These are described 
in detail in Section 12. 




Figure 26. Print engine architecture 

When several print engines are used in unison, such as in a duplexed configuration, they 
are synchronized via a shared line sync signal. Only one print engine, selected via the 
external master/slave pin, generates the line sync signal onto the shared line. 

In the 8!/ 2 " versions of the Netpage Printer, the two print engines each prints 30 Letter 
pages per minute along the long dimension of the page (1 1"), giving a line rate of 8.8 kHz 
at 1600 dpi. In the 11" Pro versions of the Netpage Printer, the two print engines each 
prints 45 Letter pages per minute along the short dimension of the page (8Vi")» giving a 
line rate of 10.2 kHz. These line rates are well within the operating frequency of the Mem- 
jet printhead, which in the current design exceeds 30 kHz. 
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1 0 Pen Controller Architecture 

The Netpage Pen controller consists of a controlling processor, a radio transceiver, a tilt 
sensor, a nib pressure sensor, a IR image sensor, flash memory, and 5 12KB of DRAM, as 
illustrated in Figure 27. 




processor address, data and control bus 




Figure 27, Pen controller architecture 

The controlling processor captures and decodes IR position tags from the page via the 
image sensor, monitors the tilt and pressure sensors, controls the autofocus voice-coil, 
controls the user interface (tricolor LED), and handles wireless communication with the 
local Netpage Printer. It consists of a medium-performance (~25MHz RISC) general-pur- 
pose microprocessor. 

Two-axis tilt sensing is provided by a two-axis accelerometer. Nib pressure sensing is pro- 
vided by an IR emitter and photodiode pair in conjunction with a reflector coupled with 
the sprung nib. 

The processor, digital transceiver components, 96x96 image sensor, flash memory and 
512KB DRAM are integrated in a single ASIC. The MEMS and analog RF components, 
acceierometers, and the IR emitter/photodiode are integrated in a single MEMS chip, also 
used in the Netpage Printer. 

The radio transceiver communicates in the unlicensed 900MHz band normally used by 
cordless telephones, and uses frequency hopping and collision detection to provide inter- 
ference-free communication. 
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11 Print Engine Page Format 

This section describes the format of compressed pages expected by the print engines. 

The raster image processors (RIPs) generate pages in this format. The compressed format 
and the print engines are designed to allow real-time page expansion during printing, to 
ensure that printing is never interrupted in the middle of a page due to data underrun. 

The Netpage Printer reproduces black at full dot resolution (1600 dpi), but reproduces 
contone color at a somewhat lower resolution using halftoning. The page description is 
therefore divided into a black layer and a contone layer. The black layer is defined to com- 
posite over the contone layer. 

The black layer consists of a bitmap containing a 1-bit opacity for each pixel. This black 
layer matte has a resolution which is an integer factor of the printer's dot resolution. The 
highest supported resolution is 1600 dpi, i.e. the printer's full dot resolution. 

The contone layer consists of a bitmap containing a 24-bit CMY color for each pixel. This 
contone image has a resolution which is an integer factor of the printer's dot resolution. 
The highest supported resolution is 267 ppi, i.e. one-sixth the printer's dot resolution. 

The contone resolution is also typically an integer factor of the black resolution, to sim- 
plify calculations in the RJPs. This is not a requirement, however. 

The black layer and the contone layer are both in compressed form for efficient storage in 
the printer's internal memory. 

11.1 Page Structure 

The Netpage Printer prints with full edge bleed using an 814" printhead. It imposes no 
margins and so has a printable page area which corresponds to the size of its paper. The 
target page size is constrained by the printable page area, less the explicit (target) left and 
top margins specified in the page description. These relationships are illustrated below. 



target top margin 



^~ target page 



printable page area 
{= physical page) 



Figure 28. Page structure 
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11.2 Compressed Page Format 

Apart from being implicitly defined in relation to the printable page area, each page 
description is complete and self-contained. There is no data stored separately from the 
page description to which the page description refers. 

The page description consists of a page header which describes the size and resolution of 
the page, followed by one or more page bands which describe the actual page content 

Table 1 shows the format of the page header. 



Table 1. Page header format 









signature 


16-bit integer 


Page header format signature. 


version 


16-bit integer 


Page header format version number. 


structure size 


16-bit integer 


Size of page header. 


target resolution (dpi) 


16-bit integer 


Resolution of target page. This is always 
1600 for the Netpage Printer. 


target page width 


16-bit integer 


Width of target page, in dots. 


target page height 


16-bit integer 


Height of target page, in dots. 


target left margin 


16-bit integer 


Width of target left margin, in dots. 


target top margin 


16-bit integer 


Height of target top margin, in dots. 


black scale factor 


16-bit integer 


Scale factor from black resolution to target 
resolution (must be 2 or greater). 


black page width 


16-bit integer 


Width of black page, in black pixels. 


black page height 


16-bit integer 


Height of black page, in black pixels. 


contone scale factor 


16-bit integer 


Scale factor from contone resolution to tar- 
get resolution (must be 6 or greater). 


contone page width 


16-bit integer 


Width of contone page, in contone pixels. 


contone page height 


16-bit integer 


Height of contone page, in contone pixels. 



The page header contains a signature and version which allow the print engine to identify 
the page header format. If the signature and/or version are missing or incompatible with 
the print engine, then the print engine can reject the page. 



The page header defines the resolution and size of the target page. The black and contone 
layers are clipped to the target page if necessary. This happens whenever the black or con- 
tone scale factors are not factors of the target page width or height. 

The target left and top margins define the positioning of the target page within the print- 
able page area. 

The black layer parameters define the pixel size of the black layer, and its integer scale 
factor to the target resolution. 

The contone layer parameters define the pixel size of the contone layer, and its integer 
scale factor to the target resolution. 

Table 2 shows the format of the page band header. 
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Table 2. Page band header format 



signature 


1 6-bit integer 


Page band header format signature. 


VCI olUI 1 


16-bit inteaer 


Page band header format version number. 


structure size 


1 6-bit integer 


Size of page band header. 


black band height 


16-bit integer 


Height of black band, in black pixels. 


black band data size 


32-bit integer 


Size of black band data, in bytes. 


contone band height 


1 6-bit integer 


Height of contone band, in contone pixels. 


contone band data size 


32-bit integer 


Size of contone band data, in bytes. 


watermark map band data size 


32-bit integer 


Size of watermark map band data, in bytes. 


tag control band height 


16-bit integer 


Height of position tag control band, in tags. 


active area map band size 


32-bit integer 


Size of active area map band data, in bytes. 


pressure-sensitive area map 
band size 


32-bit integer 


Size of pressure-sensitive area band data, 
in bytes. 



The black layer parameters define the height of the black band, and the size of its com- 
pressed band data. The variable-size black data follows the page band header. 

The contone layer parameters define the height of the contone band, and the size of its 
compressed page data, consisting of the contone color data and the associated bi-level 
watermark map. The variable-size contone data follows the black data. The variable-size 
bi-level watermark map data follows the contone data. 

The tag layer parameters define the height of the position tag control band, and the size of 
its active area and pressure-sensitive area map band data. The variable-size active area 
map data follows the watermark map data. The variable-size pressure-sensitive area map 
data follows thv active area map data. 

Table 3 shows the format of the variable-size compressed band data which follows the 
page band header. 

Table 3. Page band data format 









black data 


G4Fax 
bytestream 


Compressed bi-level black data. 


contone data 


JPEG 
bytestream 


Compressed contone CMY data. 


watermark mao 


G4Fax 
bytestream 


Compressed bi-level watermark map data. 


active area map 


bitmap 


Bi-tevel active area map data. 


pressure-sensitive area map 


bitmap 


Bi-level pressure-sensitive area map data. 



Each variable-size segment of band data is aligned to an 8-byte boundary. 

The following sections describe the format of the compressed bi-level layers and the com- 
pressed contone layer. 
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11.2.1 



Bi-level Data Compression 



11,2.1.1 



Group 3 and 4 Facsimile Compression 



The Group 3 Facsimile compression algorithm [12] losslessly compresses bi-level data for 
transmission over slow and noisy telephone lines. The bi-level data represents scanned 
black text and graphics on a white background, and the algorithm is tuned for this class of 
images (it is explicitly not tuned, for example, for halftoned bi-level images). The ID 
Group 3 algorithm runlength-encodes each scanline and then Huffman-encodes the result- 
ing runlengths. Runlengths in the range 0 to 63 are coded with terminating codes. Run- 
lengths in the range 64 to 2623 are coded with make-up codes, each representing a 
multiple of 64, followed by a terminating code. Runlengths exceeding 2623 are coded 
with multiple make-up codes followed by a terminating code. The Huffman tables are 
fixed, but are separately tuned for black and white runs (except for make-up codes above 
1728, which are common). When possible, the 2D Group 3 algorithm encodes a scanline 
as a set of short edge deltas (0, ±1, ±2, ±3) with reference to the previous scanline. The 
delta symbols are entropy-encoded (so that the zero delta symbol is only one bit long etc.) 
Edges within a 2D-encoded line which can't be delta-encoded are runlength-encoded, and 
are identified by a prefix. 1 D- and 2D-encoded lines are marked differently. 1 D-encoded 
lines are generated at regular intervals, whether actually required or not, to ensure that the 
decoder can recover from line noise with minimal image degradation. 2D Group 3 
achieves compression ratios of up to 6:1 [12]. 

The Group 4 Facsimile algorithm [6] losslessly compresses bi-level data for transmission 
over error-free communications lines (i.e. the lines are truly error-free, or error-correction 
is done at a lower protocol level). The Group 4 algorithm is based on the 2D Group 3 algo- 
rithm, with the essential modification that since transmission is assumed to be error-free, 
1 D-encoded lines are no longer generated at regular intervals as an aid to error-recovery. 
Group 4 achieves compression ratios ranging from 20:1 to 60: 1 for the CCITT set of test 
images [12]. 

The design goals and performance of the Group 4 compression algorithm qualify it as a 
compression algorithm for the bi-level layers. However, its Huffman tables are tuned to a 
lower scanning resolution (100-400 dpi), and it encodes runlengths exceeding 2623 awk- 
wardly. At 800 dpi, our maximum runlength is currently 6400. Although a Group 4 
decoder core might be available for use in the printer controller chip, it might not handle 
runlengths exceeding those normally encountered in 400 dpi facsimile applications, and so 
would require modification. 



Since most of the benefit of Group 4 comes from the delta-encoding, a simpler algorithm 
based on delta-encoding alone is likely to meet our requirements. This approach, in the 
form of the Edge Delta / Runlength (EDRL) encoding, is described in detail in another Sil- 
verbrook design document [3]. There are therefore two viable approaches to losslessly 
compressing bi-levei data: Group 4 Facsimile and EDRL. Their compression performance 
is compared below. Where this document refers to Group 4 Facsimile (G4Fax) compres- 
sion, EDRL can be substituted, purely as an implemetation decision. 

Magazine text is typically typeset in a typeface with serifs (such as Times) at a point size 
of 10. At this size a Letter page holds up to 14,000 characters, though a typical magazine 
page holds only about 7,000 characters. Text is seldom typeset at a point size smaller than 
5. At 800 dpi, text cannot be meaningfully rendered at a point size lower than 2 using a 
standard typeface. Table 4 illustrates the legibility of various point sizes. 



11.2, 1.2 Edge Delta / Runlength (EDRL) Compression 
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Table 4. Text at different point sizes 




The (prick trown fox jumps ova- \hc Uzy dog. 



The quick brown few jumps over the lazy dog. 



The quick brown fox jumps over the lazy dog. 



The quick brown fox jumps over the lazy dog. 



The quick brown fox jumps over the lazy dog. 



10 



The quick brown fox jumps over the lazy dog. 



Table 5 shows Group 4 and EDRL compression performance on pages of text of varying 
point sizes, rendered at 800 dpi. The distribution of characters on the test pages is based on 
English-language statistics [11]. 



Table 5. Group 4 and EDRL compression performance on text at 800 dpi 











^: pointsize r ^ 








2 


340,000 


2.3 


1.7 


3 


170,000 


3.2 


2.5 


4 


86,000 


4.7 


3.8 


5 


59,000 


5.5 


4.9 


6 


41,000 


6.5 


6.1 


7 


28,000 


7.7 


7.4 


8 


21,000 


9.1 


9.0 


9 


17,000 


10.2 


10.4 


10 


14,000 


10.9 


11.3 


11 


12,000 


11.5 


12.4 


12 


8,900 


13.5 


14.8 


13 


8,200 


13.5 


15.0 


14 


7,000 


14.6 


16.6 


15 


5,800 


16.1 


18.5 


20 


3,400 


19.8 


23.9 



For a point size of 9 or greater, EDRL slightly outperforms Group 4, simply because 
Group 4's runlength codes are tuned to 400 dpi. 

These compression results bear out the observation that entropy-encoded runlengths con- 
tribute much less to compression than 2D encoding, unless the data is poorly correlated 
vertically, such as in the case of very small characters. 



11.2.1.3 Black Layer Compression Format 

The 800 dpi black layer is lossiessly compressed using G4Fax (or EDRL) at a typical 
compression ratio exceeding I0:l. 
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11.2.1.4 Watermark Map Compression Format 

The 267 dpi watermark layer, which matches the 267 ppi contone color layer, is losslessly 
compressed using G4Fax (or EDRL) at a typical compression ratio exceeding 50: l. 

11.2.2 Contone Data Compression 

11.2.2.1 JPEG Compression 

The JPEG compression algorithm [9] lossily compresses a contone image at a specified 
quality level. It introduces imperceptible image degradation at compression ratios below 
5: l, and negligible image degradation at compression ratios below I0:l [13]. 

JPEG typically first transforms the image into a color space which separates luminance 
and chrominance into separate color channels. This allows the chrominance channels to be 
subsampled without appreciable loss because of the human visual system's relatively 
greater sensitivity to luminance than chrominance. After this first step, each color channel 
is compressed separately. 

The image is divided into 8x8 pixel blocks. Each block is then transformed into the fre- 
quency domain via a discrete cosine transform (DCT). This transformation has the effect 
of concentrating image energy in relatively lower-frequency coefficients, which allows 
higher-frequency coefficients to be more crudely quantized. This quantization is the prin- 
cipal source of compression in JPEG Further compression is achieved by ordering coeffi- 
cients by frequency to maximize the likelihood of adjacent zero coefficients, and then 
run length-encoding runs of zeroes. Finally, the runlengths and non-zero frequency coeffi- 
cients are entropy coded. Decompression is the inverse process of compression. 

11.2.2.2 CM Y Contone Layer Compression Format 

The CMY contone layer is compressed to an interleaved color JPEG bytestream. The 
interleaving is required for space-efficient decompression in the printer, but may restrict 
the decoder to two sets of Huffman tables rather than four (i.e. one per color channel) [13]. 
If luminance and chrominance are separated, then the luminance channels can share one 
set of tables, and the chrominance channels the other set. 

If luminance/chrominance separation is deemed necessary, either for the purposes of table 
sharing or for chrominance subsampling, then CMY is converted to YCrCb and Cr and Cb 
are duly subsampled. 

The JPEG bytestream is complete and self-contained. It contains all data required for 
decompression, including quantization and Huffman tables. 
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12 Print Engine 

1 2.1 Halftoner/Compositor 

The halftoner/compositor unit (HCU) (Figure 30) combines the functions of halftoning the 
contone CMY layer to bi-level CMY, and compositing the black layer over the halftoned 
contone layer. It also selects between the normal and the "watermark" dither matrix on a 
pixel-by-pixel basis, based on the corresponding value in the watermark map. 

The input to the HCU is an expanded 267 ppi CMY contone layer, an expanded 267 dpi 
watermark map, and an expanded 1600 dpi black layer. The output from the HCU is a set 
of 1600 dpi bi-level CMY image lines. 

Once started, the HCU proceeds until it detects an end-of-page condition, or until it is 
explicitly stopped via its control register. 

The HCU generates a page of dots of a specified width and length. The width and length 
must be written to the page width and page length registers prior to starting the HCU. The 
page width corresponds to the width of the printhead. The page length corresponds to the 
length of the target page. 

The HCU generates target page data between specified left and right margins relative to 
the page width. The positions of the left and right margins must be written to the left mar- 
gin and right margin registers prior to starting the HCU. The distance from the left margin 
to the right margin corresponds to the target page width. 

The HCU consumes black and contone/watermark data according to specified black and 
contone page widths. These page widths must be written to the black page width and con- 
tone page width registers prior to starting the HCU. The HCU clips black and contone data 
to the target page width. This allows the black and contone page widths to exceed the tar- 
get page width without requiring any special end-of-line logic at the input FIFO level. 

The relationships between the page width, the black and contone page widths, and the 
margins are illustrated in Figure 29. 



target left margin target page width 



target right margin 



black page width 



contone page width 



page width (of printhead) 



Figure 29. Relationships between page widths and margins 
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The HCU scales contone data to printer resolution both horizontally and vertically based 
on a specified scale factor. This scale factor must be written to the contone scale factor 
register prior to starting the HCU. 



Table 6. Halftoner/compositor control and configuration registers 




start 


1 


Start the HCU. 


stop 


1 


Stop the HCU. 


page width 


14 


Page width of printed page, in dots. This is the number of dots which 
have to be generated for each line. 


left margin 


14 


Position of left margin, in d?ts. 


right margin 


14 


Position of right margin, in dots. 


page length 


15 


Page length of printed page, in dots. This is the number of lines 
which have to be generated for each page. 


black page width 


14 


Page width of black layer, in dots. Used to detect the end of a black 
line. 


contone page 
width 


14 


Page width of contone layer, in dots. Used to detect the end of a 
contone line. 


contone 
scale factor 


4 


Scale factor used to scale contone data to bi-level resolution. 



The consumer of the data produced by the HCU is the printhead interface. The printhead 
interface requires bi-level CMY image data in planar format, i.e. with the color planes 
separated. Further, it also requires that even and odd pixels are separated. The output stage 
of the HCU therefore uses 6 parallel pixel FIFOs, one each for even cyan, odd cyan, even 
magenta, odd magenta, even yellow, and odd yellow, 

i 
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Figure 30. Halftoner/compositor unit 
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The input contone CMY FIFO is a full 7KB line buffer. The line is used contone scale fac- 
tor times to effect vertical up-scaling via line replication. FIFO write address wrapping is 
disabled until the start of the last use of the line. 



12.1.1 Dither 

The dither unit converts a 24-bit contone CMY value into a 3-bit bi-level CMY value. 
Each color component is independently compared with the 8-bit threshold value at the 
current dot position in the dither cell (see Figure 31). 

There are two programmable 64x64x8-bit dither cells: a normal dither cell and a "water- 
mark" dither cell. The 1-bit watermark value associated with the current contone pixel 
controls the selection of the watermark or normal threshold value. 



The dither cell address generator contains a pair of 6-bit row and column address registers. 
Both registers are initialized to zero. The row address is incremented on every dot line 
advance, modulo 64. The column address is incremented on every dot clock, modulo 64, 
and is reset on a dot line advance. 
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Figure 31. Dither, with watermarking 



12.1.2 Composite 

The composite unit composites a black layer dot over a halftoned CMY layer dot. If the 
black layer opacity is one, then the halftoned CMY is set to black (i.e. all ones). The black 
layer opacity is therefore simply ORed with each of the halftoned C, M, and Y values. 



12.1.3 Clock Enable Generator 

The clock enable generator generates enable signals for clocking the contone CMY/water- 
mark pixel input, the black dot input, and the CMY dot output. 

As described earlier, the contone pixel input buffer is used as both a line buffer and a 
FIFO. Each line is read once and then used contone scale factor times. FIFO write address 
wrapping is disabled until the start of the final replicated use of the line, at which time the 
clock enable generator generates a contone line advance enable signal which enables 
wrapping. 
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The clock enable generator also generates an even signal which is used to select the even 
or odd set of output dot FIFOs, and a margin signal which is used to generate white dots 
when the current dot position is in the left or right margin of the page. 

The clock enable generator uses a set of counters. Hie internal logic of the counters is 
defined in Table 7. The logic of the clock enable signals is defined in Table 8. 

Table 7. Clock enable generator counter logic 



dot 


D 


14 


page width 


RP 3 v EOL b 


(D>0) a cik 


line 


L 


15 


page length 


RP 


(L>0) a EOL 


left margin 


LM 


14 


left margin 


RP v EOL 


(LM>0) a elk 


right margin 


RM 


14 


right margin 


RP v EOL 


(RM>0) a elk 


even/odd dot 


E 


1 


0 


RP v EOL 


elk 


black dot 


BD 


14 


black width 


RP v EOL 


<LM=0) a (BD>0) a elk 


contone dot 


CD 


14 


contone width 


RP v EOL 


(LM=0) a (CD>0) a elk 


contone 
sub-pixel 


CSP 


4 


contone scale 
factor 


RP v EOL v (CSP=0) 


(LM=0) a elk 


contone 
sub-line 


CSL 


4 


contone scale 
factor 


RP v (CSL=0) 


EOL a elk 



a. RP (reset page) condition: external signal 

b. EOL (end-of-line) condition: (D=0) a (BD=0) a (CD=0) 



Table 8. Clock enable generator output signal logic 







output dot clock enable 


(D>0) a -,EOP a 


black dot clock enable 


(LM=0) a (BD>0) a -,EOP 


contone pixel clock enable 


(LM=0) a (CD>0) a (CSP=0) a ^EOP 


contone line advance enable 


(CSL=0) a -,EOP 


even 


E=0 


margin 


(LM=0) v (RM=0) 



a. EOP (end-of-page) condition: L=0 



12.2 Printhead Interface 

Netpage Printer uses an 8 14" CMYK Memjet printhead, as described in Section 14. The 
printhead consists of 17 segments arranged in 2 segment groups. The first segment group 
contains 9 segments, and the second group contains 8 segments. There are 13,600 nozzles 
of each color in the printhead, making a total of 54,400 nozzles. 

The printhead interface is a standard Memjet printhead interface, as described in Section 
15, configured with the following operating parameters: 

• MaxColors = 4 

• SegmentsPerXfer = 9 

• SegmentGroups = 2 
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Although the printhead interface has a number of external connections, not all used for an 
8!/ 2 " printhead, so not all are connected to external pins on the print engine. Specifically, 
the value for SegmentGroups implies that there are only 2 SRCIock pins and 2 SenseSegSe- 
lect pins. All 36 ColorData pins are required, however. 



12-3 Position Tag Encoder 

The position tag encoder encodes the page id of the page being printed, together with the 
current x-y position on the page, into an error-correctably encoded position tag which is 
subsequently printed in infrared (IR) ink on the page. 

The position tag encoder takes the following as input: 

• the page id 

• a pressure sensitive area bitmap at tag resolution 

• an active area bitmap at tag resolution 

It writes a bi-level IR bitstream to the bi-level IR FIFO. The position tag encoder design as 
defined here allows a single page id per printed page, and provides for a page size of up to 
21. 7 inches per dimension (17 x 4 x 512 / 1600). In addition, the position tag encoder 
allows for both landscape and portrait orientations. 

The position tag encoder consists of two stages connected by a buffer. The first stage, the 
tag data encoder, Reed-Solomon encodes the data to be placed in the tags. The second 
stage, the tag formatter, places the encoded data into the tag format and passes it on to the 
bi-level IR FIFO. Since the tag formatter runs one line of tags behind the tag data encoder, 
the tag data buffer is in fact a double-buffer. The relationship is shown in Figure 32. 




Figure 32. Two stages of position tag encoder 

The position tag encoder provides full macrodot-to-dot conversion, thereby eliminating 
any special knowledge of macrodots from the bi-level FIFO user. However, the position 
tag encoder itself does make use of the redundancy caused by dot replication in macrodot 
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formation with respect to the dot axis only. Since the macrodot-to-dot ratio is 1 :4, the posi- 
tion tag encoder operates at 1/4 of the dot frequency (60 MHz). 

12.3.1 Tag Data Buffer 

The tag data buffer consists of two identical buffers. One is read by the tag formatter while 
the other is being written to by the tag data encoder. The two buffers are then logically 
swapped. 

Each buffer contains 256 T bits, where T is the maximum number of tags in a given printed 
line of dots. The maximum amount of memory required for each buffer is 16KBytes 
(when T - 5 12). To support a 12-inch printhead, r= 283, so the memory required for each 
buffer is 9056 bytes (55% of the maximum). Note that the remainder of the position tag 
encoder does not change in size based on T. 

As the encoded bits are generated by the tag data encoder, they are written to consecutive 
bits in the tag data buffer. The data bits are read out in random-access fashion by the tag 
formatter. Having 256 bits allocated to each tag allows the tag number to be used for gen- 
erating the high bits of the address and the low 8 bits of the address to come from the 
sub-tag address generator. 

The tag data buffer therefore has the structure as shown by Figure 33: 

256 bits 



3 



B 

03 
CO 



196 bits 60 bits 
K ► 



data bits for tag 0 



data bits for tag 1 



data bits for tag 2 



data bits for tag T-1 



unused 



Figure 33. Tag data buffer logical structure 

12.3.2 Tag Data Encoder 

It is the responsibility of the tag data encoder to produce the 28 bits of encoded mode data 
and 168 bits of encoded tag data for a total of 1 96 bits of encoded data. The encoding 
scheme for position tags is defined in [5]. 

Each tag is represented on the page by a 1 7x17x4x4 structure of dots. However, since the 
tag data formatter is running at only 1/4 of the dot frequency, this results in a time of 1 156 
cycles (17x17x4) per tag. 

The tag data encoder and control block functions are provided by a simple microprocessor 
core running at 60 MHz. This is desirable compared to the design effort to implement a 
specific Reed-Solomon encoder for two types of encoding and specific tag codeword con- 
struction. 
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The 196 bits of encoded tag data are written to one of the tag data buffers while the other 
is being read from by the tag formatter function. 

The coordinates encoded within the tags for a given line of tags will depend on the width 
of the printhead and whether or not the pages are being printed in portrait or landscape 
mode, as shown in Figure 34. 



increasing x 



1 




PORTRAIT 



increasing y 




LANDSCAPE 



Figure 34. Relationship of coordinates to tags in a tag line 

• If processing a portrait page, each printed line corresponds to changes in x coordi- 
nates. A printed line of tags therefore has a constant y coordinate, a start x coordinate 
of 0, and end x coordinate of T-I with a Ax of /. To advance to the next line of tags, the 
y coordinate increases by 1 and x is reset to 0. 

• If processing a landscape page, each printed line corresponds to changes in y coordi- 
nates. A printed line of tags therefore has a constant x coordinate, a start y coordinate 
of 0, and an end y coordinate of T-l with a Ay of 1. To advance to the next line of tags, 
the x coordinate is decreased by 1 and y is reset to 0. 

The high level control function for coordinate generation is outlined here in pseudocode. 



if portrai tMode 

For tagline = 0 to maxTagLines 
For tag = 0 to lastTaglnLine 

EncocieTag ( tag, pageld, tag, tagLine) 
EndFor 
EndFor 
else 

tagX = maxTagLines 
For tagline = 0 to maxTagLines 
For tag = 0 to lastTaglnLine 

EncodeTag ( tag, pageld, tagX, tag) 
tagX = tagX - 1 
EndFor 
EndFor 
End If 



In relation to the EncodeTag function, an examination of the tag structure reveals: 

• of the 168 data bits, 90 bits are copied to a maximum of 108 bits in the output with 
only trivial change. The remaining bits are generated check words based on GF(64). 
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• of the 28 mode bits, 8 bits are directly copied to the output. The remaining 20 are gen- 
erated check words based on GF(16). 

Therefore the 8 mode bits output and at least 90 bits of the data bits output can be output at 
a rate approximating 1 cycle per bit. The remaining 70 bits must be generated using Reed- 
Solomon encoding. This allows approximately 1000 cycles for 70 bits, or approximately 
14 cycles per encoded bit. Encoding over GF(16) and GF(64) can be accomplished using 
small tables totalling 64 and 256 bytes respectively. 

The bits are stored in the tag data buffer in bit generation order in order to simplify the 
writing process. The reading process (in the tag formatter) has random access to the gener- 
ated bits, but has specific addressing hardware to assist in this task. The order for writing 
bits is as follows: 

• 90- 1 08 bits of data ( 1 5- 1 8 x 6-bit codewords, depending on whether 1 s or 0s had to be 
inserted to generate non 000000 and non 111111 codewords) based on the 90 bits of data 
(64 bits of pageld, 9 bits of tagX, 9 bits of tagY, I bit from the active area bitmap at tag 
resolution, 1 bit from the pressure sensitive area bitmap at tag resolution and 6 
reserved bits). 

• 78-60 bits of check words (13-10 x 6-bit check words, depending on how many data 
codewords were written) 

• 8 bits of mode data (2 x 4-bit codewords) 

• 20 bits of check words (5 x 4-bit check words) 

12.3.3 Tag Formatter 

The tag formatter is responsible for merging the encoded tag data with the tag structure, 
and placing the dots in the IR buffer in the correct order for printing. The encoded tag data 
is read from the tag data buffer as previously generated by the tag data encoder. The for- 
matted dots are placed in the bi-Ieve! IR buffer such that the same data is clocked in 4 
times. This allows the tag formatter to run at 1/4 of the dot rate. 

We use a simple set of counters for formatting a set of 68 lines of dots (a set of 68 lines 
equates to 17 rows of 4-dot macrodots). The logic for the 68 lines of dots can be repeated 
until the page has finished printing. The within-tag counters index into an address table of 
9-bit entries with the following attributes: 

• If the entry's high bit = 0, then the macrodot comes from an encoded data bit The 
encoded data bit to use is given by the concatenation of the current tag# (10 bits) and 8 
bits of address from the low 8-bits of the entry. 

• If the entry's high bit = 1, then the macrodot comes from the constant structure of a 
position tag (the bull's-eye and orientation bits). The entry's low bit determines the 
state of the macrodot. 

The address table defines the structure of a positional tag at the macrodot level. It there- 
fore has a constant size of 289 x 9-bit entries. The stored 8-bit addresses simply combine 
the tag encoding structure with the order that the bits are written to the tag data buffer. For 
the constant part of the tag (the bull's-eye and orientation bits), the entries are simply 
100000000 for a white dot and 100000001 for a black dot. 

The tag formatter is shown in pseudocode form: 



For line = 0 to 16 
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For dotY =* 0 to 3 

For tag - 0 to numTagsInLine 
For pixel = 0 to 16 

adr = TableLookup [line, pixel] 
If (adr 5=0) 

bit = TagDataBuf f er [tag I adr 0 _ 4 ] 
Else 

bit = adr 0 
Endlf 

Place 4 copies of bit in FIFO 
EndFor 
EndFor 
EndFor 
EndFor 

Swap TagDataBuf fers 



The pseudocode is readily transferred to logic, as illustrated by Figure 35. 
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Figure 35. Tag formatter 
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13 Print Engine Driver 

This section discusses rasterizing pages to the internal compressed page format expected 
by the print engine, as defined in Section 1 1, in terms of the compressed page driver which 
hides this device-dependent behavior from the higher-level raster image processor (RIP). 
The relationship between the RIP, the graphics system, the compressed page driver, and 
the print engine, is illustrated in Figure 36. 




Figure 36. RIP and print engine driver 

The RIP and the graphics system are considered generic components and are not defined 

further at this stage. 

13.1 Graphics and Imaging Model 

The compressed page driver is closely coupled with the graphics system used by the RIP, 
so that the driver can provide device-specific handling for different graphics and imaging 
operations, in particular compositing operations and text operations. 

The graphics system renders images and graphics to a nominal resolution specified by the 
compressed page driver, but allows the compressed page driver to take control of render- 
ing text. In particular, the graphics system provides sufficient information to the com- 
pressed page driver to allow it to render and position text at a higher resolution than the 
nominal device resolution. 

The host graphics system requires random access to a contone page buffer at the nominal 
device resolution, into which it composites graphics and imaging objects, but it allows the 
compressed page driver to take control of the actual compositing - i.e. the compressed 
page driver manages the page buffer. 

13.2 Two-Layer Page Buffer 

The compressed page format contains a 267 ppi contone layer and an 800 dpi black layer. 
The black layer is conceptually above the contone layer, i.e. the black layer is composited 
over the contone layer by the print engine. The compressed page driver therefore main- 
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tains a page buffer which correspondingly contains a medium-resolution contone layer 
and a high-resolution black layer. 

The graphics systems renders and composites objects into the page buffer bottom-up - i.e. 
later objects obscure earlier objects. This works naturally when there is only a single layer, 
but not when there are two layers which will be composited later. It is therefore necessary 
to detect when an object being placed on the contone layer obscures something on the 
black layer. 

When obscuration is detected, the obscured black pixels are composited with the contone 
layer and removed from the black layer. The obscuring object is then laid down on the 
contone layer, possibly interacting with the black pixels in some way. If the compositing 
mode of the obscuring object is such that no interaction with the background is possible, 
then the black pixels can simply be discarded without being composited with the contone 
layer. In practice, of course, there is little interaction between the contone layer and the 
black layer, since images and text rarely overlap. 

The compressed page driver specifies a nominal page resolution of 267 ppi to the graphics 
system. Where possible the compressed page driver relies on the graphics system to render 
image and graphics objects to the pixel level at 267 ppi, with the exception of black text. 
The compressed page driver fields all text rendering requests, detects and renders black 
text at 800 dpi, but returns non-black text rendering requests to the graphics system for 
rendering at 267 ppi. 

Ideally the graphics system and the compressed page driver manipulate color in 
device-independent RGB, deferring conversion to device-specific CMY until the page is 
complete and ready to be sent to the printer. This reduces page buffer requirements and 
makes compositing more rational. Compositing in in a device-dependent color space is not 
ideal. 

Ultimately the graphics system asks the compressed page driver to composite each ren- 
dered object into the compressed page driver's page buffer. Each such object uses 24-bit 
contone RGB, and has an explicit (or implicitly opaque) opacity channel. 



page buffer 



medium-res 




medium-res 




■ 

high-res 


contone layer 




black layer 




black layer 


{24-bit RGB) 
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Figure 37. Two-layer page buffer 

The compressed page driver maintains the two-layer page buffer in three parts. The first 
part is the medium-resolution (267 ppi) contone layer. This consists of a 24-bit RGB bit- 
map. The second part is a medium-resolution black layer. This consists of an 8-bit opacity 
bitmap. The third part is a high-resolution (800 dpi) black layer. This consists of a 1-bit 
opacity bitmap. The medium-resolution black layer is a subsampled version of the 
high-resolution opacity layer. In practice, assuming the medium resolution is an integer 
factor n of the high resolution (e.g. n = 800 / 267 = 3), each medium-resolution opacity 
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value is obtained by averaging the corresponding n x n high-resolution opacity values. 
This corresponds to box-filtered subsampling. The subsampling of the black pixels effec- 
tively antialiases edges in the high-resolution black layer, thereby reducing ringing arti- 
facts when the contone layer is subsequently JPEG-compressed and decompressed. 

The structure and size of the page buffer is illustrated in Figure 37. 

13.3 Compositing Model 

For the purposes of discussing the page buffer compositing model, we define the follow- 
ing variables. 



Table 9. Compositing variables 













n 


medium to high resolution scale factor 






C C 


contone layer color 


medium 


8-bit color component 


c G 


contone object color 


medium 


8-bit color component 


«G 


contone object opacity 


medium 


8-bit opacity 


<*L 


medium-resolution black layer opacity 


medium 


8-bit opacity 




black layer opacity 


high 


1-bit opacity 


«r 


black object opacity 


high 


1-bit opacity 



When a black object of opacity a T is composited with the black layer, the black layer is 
updated as follows: 



n - I n - \ 

a ^ = -lyy^a, . (2) 

/ = 0y = 0 ■ 

The object opacity is simply ored with the black layer opacity (Eq. 1), and the correspond- 
ing part of the medium-resolution black layer is re-computed from the high-resolution 
black layer (Eq. 2). 

When a contone object of color Cq and opacity ol g is composited with the contone layer, 
the contone layer and the black layer are updated as follows: 

c c,. v = C Cj[ (\ -ol Lji ) if (a Gr v >0) (3) 
ol l = 0 if (a G v >0) (4) 
a B = 0 if (a G >0) (5) 

C c, , = c c v . ( 1 - «g,. ) + c c,. «c, v (6) 

Wherever the contone object hides the black layer, even if not fully opaquely, the affected 
black layer pixels are composited with the contone layer (Eq. 3) and removed from the 
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black layer (Eq. 4 and Eq. 5). The contone object is then composited with the contone 
layer (Eq. 6). 



Once page rendering is complete, the compressed page driver converts the contone layer 
to printer-specific CMY with the help of color management functions provided by the 
graphics system. 

The compressed page driver then compresses and packages the black layer and the con- 
tone layer into the compressed page format defined in Section 11. This is subsequently 
expanded in real time by the print engine. 

The forward discrete cosine transform (DCT) is the costliest part of JPEG compression. In 
current high-quality software implementations, the forward DCT of each 8x8 block 
requires 12 integer multiplications and 32 integer additions [10]. This places a trivial addi- 
tional load on each RIP DSP. 



13.4 



Page Compression 
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14 



Memjet Printhead 



A Memjet printhead is a drop-on-demand 1600 dpi inkjet printer that produces bi-level 
dots in up to 4 colors to produce a printed page of a particular width. Since the printhead 
prints dots at 1600 dpi, each dot is approximately 22.5u.m in diameter, and spaced 
15.875p.rn apart. Because the printing is bi-level, the input image should be dithered or 
error-diffused for best results. 

Typically a Memjet printhead for a particular application is page- width. This enables the 
printhead to be stationary and allows the paper to move past the printhead. Figure 38 illus- 
trates a typical configuration. 



A Memjet printhead is composed of a number of identical 1/2 inch Memjet segments. The 
segment is therefore the basic building block for constructing a printhead. 



14.1 The Structure of a Memjet Segment 

This section examines the structure of a single segment, the basic building block for con- 
structing Memjet printheads. 

14.1.1 Grouping of Nozzles Within a Segment 



The nozzles within a single segment are grouped for reasons of physical stability as well 
as minimization of power consumption during printing. In terms of physical stability, a 
total of 10 nozzles share the same ink reservoir. In terms of power consumption, groupings 
are made to enable a low-speed and a high-speed printing mode. 

Memjet segments support two printing speeds to allow speed/power consumption 
trade-ofTs to be made in different product configurations. 

In the low-speed printing mode, 4 nozzles of each color are fired from the segment at a 
time. The exact number of nozzles fired depends on how many colors are present in the 
printhead. In a four color (e.g. CMYK) printing environment this equates to 16 nozzles fir- 
ing simultaneously. In a three color (e.g. CMY) printing environment this equates to 12 
nozzles firing simultaneously. To fire all the nozzles in a segment, 200 different sets of 
nozzles must be fired. 



Paper 





Figure 38. A Memjet printhead 
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In the high-speed printing mode, 8 nozzles of each color are fired from the segment at a 
time. The exact number of nozzles fired depends on how many colors are present in the 
printhead. In a four color (e.g. CMYK) printing environment this equates to 32 nozzles fir- 
ing simultaneously. In a three color (e.g. CMY) printing environment this equates to 24 
nozzles firing simultaneously. To fire all the nozzles in a segment, 100 different sets of 
nozzles must be fired. 

The power consumption in the low-speed mode is half that of the high-speed mode. Note, 
however, that the energy consumed to print a page is the same in both cases. 

14. 1.1.1 10 Nozzles Make a Pod 

A single pod consists of I0 nozzles sharing a common ink reservoir. 5 nozzles are in one 
row, and 5 are in another. Each nozzle produces dots 22.5ujti in diameter spaced on a 
I5.875u.rn grid to print at 1600 dpi. Figure 39 shows the arrangement of a single pod, with 
the nozzles numbered according to the order in which they must be fired. 




Figure 39. A single pod, numbered by firing order 

Although the nozzles are fired in this order, the relationship of nozzles and physical place- 
ment of dots on the printed page is different. The nozzles from one row represent the even 
dots from one line on the page, and the nozzles on the other row represent the odd dots 
from the adjacent line on the page. Figure 40 shows the same pod with the nozzles num- 
bered according to the order in which they must be loaded. 




Figure 40. A single pod, numbered by load order 

The nozzles within a pod are therefore logically separated by the width of 1 dot.. The exact 
distance between the nozzles will depend on the properties of the Memjet firing mecha- 
nism. The printhead is designed with staggered nozzles designed to match the flow of 
paper. 

14. 1. 1.2 1 Pod of Each Color Makes a Chromapod 

One pod of each color are grouped together into a chromapod. The number of pods in a 
chromapod will depend on the particular application. In a monochrome printing system 
(such as one that prints only black), there is only a single color and hence a single pod. 
Photo printing application printheads require 3 colors (cyan, magenta, yellow), so Memjet 
segments used for these applications will have 3 pods per chromapod (one pod of each 
color). The expected maximum number of pods in a chromapod is 4, as used in a CMYK 
(cyan, magenta, yellow, black) printing system (such as a desktop printer). This maximum 
of 4 colors is not imposed by any physical constraints - it is merely an expected maximum 
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from the expected applications (of course, as the number of colors increases the cost of the 
segment increases and the number of these larger segments that can be produced from a 
single silicon wafer decreases). 

A chromapod represents different color components of the same horizontal set of 10 dots 
on different lines. The exact distance between different color pods depends on the Memjet 
operating parameters, and may vary from one Memjet design to another. The distance is 
considered to be a constant number of dot-widths, and must therefore be taken into 
account when printing: the dots printed by the cyan nozzles will be for different lines than 
those printed by the magenta, yellow or black nozzles. The printing algorithm must allow 
for a variable distance up to about 8 dot-widths between colors. Figure 41 illustrates a sin- 
gle chromapod for a CMYK printing application. 




Figure 41. A Single Chromapod Contains 1 Pod of each Color 

14.1.1.3 5 Chromapods Make a Podgroup 

5 chromapods are organized into a single podgroup. A podgroup therefore contains 50 
nozzles for each color. The arrangement is shown in Figure 42, with chromapods num- 
bered 0-4 and using a CMYK chromapod as the example. Note that the distance between 
adjacent chromapods is exaggerated for clarity. 

0 12 3 4 




5 chromapods 



Figure 42. A Single Podgroup Contains 5 Chromapods 

14. 1.1.4 2 Podgroups Make a Phasegroup 

2 podgroups are organized into a single phasegroup. The phasegroup is so named because 
groups of nozzles within a phasegroup are fired simultaneously during a given firing 
phase (this is explained in more detail below). The formation of a phasegroup from 2 pod- 
groups is entirely for the purposes of low-speed and high-speed printing via 2 Pod- 
groupEnable lines. 

During low-speed printing, only one of the two PodgroupEnable lines is set in a given fir- 
ing pulse, so only one podgroup of the two fires nozzles. During high-speed printing, both 
PodgroupEnable lines are set, so both podgroups fire nozzles. Consequently a low-speed 
print takes twice as long as a high-speed print, since the high-speed print fires twice as 
many nozzles at once. 
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Figure 43 illustrates the composition of a phasegroup. The distance between adjacent pod- 
groups is exaggerated for clarity. 




Figure 43. A single phasegroup contains 2 podgroups 

14.1.1.5 2 Phasegro ups Make a Firegroup 

Two phasegroups (PhasegroupA and PhasegroupB) are organized into a single firegroup, 
with 4 firegroups in each segment. Firegroups are so named because they all fire the same 
nozzles simultaneously. Two enable lines, AEnable and BEnable, allow the firing of Pha- 
segroupA nozzles and PhasegroupB nozzles independently as different firing phases. The 
arrangement is shown in Figure 44. The distance between adjacent groupings is exagger- 
ated for clarity. 




\ A single Firegroup 
\ contains 2 phasegroups 




Figure 44. Relationship between Segments, Firegroups, 
Phasegroups, Podgroups and ChromaPods 
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14.1.1.6 Nozzle Grouping Summary 

Table 10 is a summary of the nozzle groupings in a segment assuming a CMYK chroma- 
pod. 

Table 10. Nozzle Groupings for a single segment 



Nozzle 


Base unit 


1:1 


1 


Pod 


Nozzles per pod 


10:1 


10 


Chromapod 


Pods per chromapod 


C:1 


10C 


Podgroup 


Chromapods per podgroup 


5:1 


50C 


Phasegroup 


Podgroups per phasegroup 


2:1 


100C 


Firegroup 


Phasegroups per firegroup 


2:1 


200C 


Segment 


Ftregroups per segment 


4:1 


800C 



The value of C, the number of colors contained in the segment, determines the total num- 
ber of nozzles. 

• With a 4 color segment, such as CMYK, the number of nozzles per segment is 3,200. 

• With a 3 color segment, such as CMY, the number of nozzles per segment is 2,400. 

• In a monochrome environment, the number of nozzles per segment is 800. 

14.1.2 Load and Print Cycles 

A single segment contains a total of 800C nozzles, where C is the number of colors in the 
segment. A Print Cycle involves the firing of up to all of these nozzles, dependent on the 
information to be printed. A Load Cycle involves the loading up of the segment with the 
information to be printed during the subsequent Print Cycle. 

Each nozzle has an associated NozzleEnable bit that determines whether or not the nozzle 
will fire during the Print Cycle. The NozzleEnable bits (one per nozzle) are loaded via a 
set of shift registers. 

Logically there are C shift registers per segment (one per color), each 800 deep. As bits 
are shifted into the shift register for a given color they are directed to the lower and upper 
nozzles on alternate pulses. Internally, each 800-deep shift register is comprised of two 
400-deep shift registers: one for the upper nozzles, and one for the lower nozzles. Alter- 
nate bits are shifted into the alternate internal registers. As far as the external interface is 
concerned however, there is a single 800 deep shift register. 

Once all the shift registers have been fully loaded (800 load pulses), all of the bits are 
transferred in parallel to the appropriate NozzleEnable bits. This equates to a single paral- 
lel transfer of 800C bits. Once the transfer has taken place, the Print Cycle can begin. The 
Print Cycle and the Load Cycle can occur simultaneously as long as the parallel load of all 
NozzleEnable bits occurs at the end of the Print Cycle. 

14.1.2.1 Load Cycle 

The Load Cycle is concerned with loading the segment's shift registers with the next Print 
Cycle's NozzleEnable bits. 
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Each segment has C inputs directly related to the C shift registers (where C is the number 
of colors in the segment). These inputs are named ColorNData, where N is 1 to C (for 
example, a 4 color segment would have 4 inputs labeled Color I Data, Color2Data y 
Colo r3 Data and Color4Data). A single pulse on the SRClock line transfers C bits into the 
appropriate shift registers. Alternate pulses transfer bits to the lower and upper nozzles 
respectively. A total of 800 pulses are required for the complete transfer of data. Once all 
800C bits have been transferred, a single pulse on the PTransfer line causes the parallel 
transfer of data from the shift registers to the appropriate NozzleEnable bits. 

The parallel transfer via a pulse on PTransfer must take place after the Print Cycle has fin- 
ished. Otherwise the NozzleEnable bits for the line being printed will be incorrect. 

It is important to note that the odd and even dot outputs, although printed during the same 
Print Cycle, do not appear on the same physical output line. The physical separation of 
odd and even nozzles within the printhead, as well as separation between nozzles of differ- 
ent colors ensures that they will produce dots on different lines of the page. This relative 
difference must be accounted for when loading the data into the printhead. The actual dif- 
ference in lines depends on the characteristics of the inkjet mechanism used in the print- 
head. The differences can be defined by variables D, and D 2 where Di is the distance 
between nozzles of different colors, and D 2 is the distance between nozzles of the same 
color. Table 1 1 shows the dots transferred to a C color segment on the first 4 pulses. 



Table 11. Order of Dots Transferred to a Segment 































1 
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N 


N+D<| a 




N+(C-1)D 1 


2 




1 


N+D 2 b 


N+D}+D2 


N+20,+02 


N+(C-1)D 1 +D 2 


3 




2 


N 


N+D 1 


N+2D, 


N+(C-1)D 1 


4 




3 


N+D 2 


N+D.,+D2 


N+2DT+D2 


N+(C-1)D 1 +D 2 



a. D t = number of lines between the nozzfes of one color and the next (likely = 4-8) 



b. D 2 = number of lines between two rows of nozzles of the same color (likely = 1 ) 
And so on for all 800 pulses. 

Data can be clocked into a segment at a maximum rate of 20 MHz, which will load the 
entire 800C bits of data in 40u.s. 

14.1.2.2 Print Cycle 

A single Memjet printhead segment contains 800 nozzles. To fire them all at once would 
consume too much power and be problematic in terms of ink refill and nozzle interference. 
This problem is made more apparent when we consider that a Memjet printhead is com- 
posed of multiple 1/2 inch segments, each with 800 nozzles. Consequently two firing 
modes are defined: a low-speed printing mode and a high-speed printing mode: 

• In the low-speed print mode, there are 200 phases, with each phase firing 4C nozzles 
(C per firegroup, where C is the number of colors). 

• In the high-speed print mode, there are 1 00 phases, with each phase firing 8C nozzles, 
(2C per firegroup, where C is the number of colors). 

The nozzles to be fired in a given firing pulse are determined by 
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• 3 bits ChromapodSelect (select i of 5 chromapods from a firegroup) 

• 4 bits NozzleSeiect (select I of 1 0 nozzles from a pod) 

• 2 bits of PodgroupEnable lines (select 0, 1 , or 2 podgroups to fire) 

When one of the PodgroupEnable lines is set, only the specified Podgroup's 4 nozzles will 
fire as determined by ChromapodSelect and NozzleSeiect. When both of the PodgroupEn- 
able lines are set, both of the podgroups will fire their nozzles. For the low-speed mode, 
two fire pulses are required, with PodgroupEnable = 10 and 01 respectively. For the 
high-speed mode, only one fire pulse is required, with PodgroupEnable =11. 

The duration of the firing pulse is given by the A Enable and BEnable lines, which fire the 
PhasegroupA a~d PhasegroupB nozzles from all firegroups respectively. The typical dura- 
tion of a firing pulse is 1 .3 - 1 .8 \xs. The duration of a pulse depends on the viscosity of the 
ink (dependent on temperature and ink characteristics) and the amount of power available 
to the printhead. See Section 14.1.3 on page 61 for details on feedback from the printhead 
in order to compensate for temperature change. 

The A Enable and BEnable are separate lines in order that the firing pulses can overlap. 
Thus the 200 phases of a low-speed Print Cycle consist of 100 A phases and 100 B phases, 
effectively giving 100 sets of Phase A and Phase B. Likewise, the 100 phases of a 
high-speed print cycle consist of 50 A phases and 50 B phases, effectively giving 50 
phases of phase A and phase B. 

Figure 45 shows the AEnable and BEnable lines during a typical Print Cycle. In a high- 
speed print there are 50 2p.s cycles, while in a low-speed print there are 100 2|is cycles. 



For the high-speed printing mode, the firing order is: 

• ChromapodSelect 0, NozzleSeiect 0, PodgroupEnable 1 1 (Phases A and B) 

• ChromapodSelect 1 , NozzleSeiect 0, PodgroupEnable 1 1 (Phases A and B) 

• ChromapodSelect 2, NozzleSeiect 0, PodgroupEnable 1 1 (Phases A and B) 

• ChromapodSelect 3, NozzleSeiect 0, PodgroupEnable 1 1 (Phases A and B) 

• ChromapodSelect 4, NozzleSeiect 0, PodgroupEnable 1 1 (Phases A and B) 

• ChromapodSelect 0, NozzleSeiect 1 , PodgroupEnable 1 1 (Phases A and B) 

• ChromapodSelect 3, NozzleSeiect 9, PodgroupEnable 1 1 (Phases A and B) 

• ChromapodSelect 4, NozzleSeiect 9, PodgroupEnable 1 1 (Phases A and B) 



AEnable 




BEnable 




Figure 45. AEnable and 



BEnable During a Typical Print Cycle 
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For the low-speed printing mode, the firing order is similar. For each phase of the high 
speed mode where PodgroupEnable was 11, two phases of PodgroupEnable = 01 and 10 
are substituted as follows: 



ChromapodSelect 0, NozzIeSelect 0, 


PodgroupEnable 


01 


(Phases 


A 


and 


B) 


ChromapodSelect 0, NozzIeSelect 0, 


PodgroupEnable 


10 


(Phases 


A 


and 


B) 


ChromapodSelect 1, NozzIeSelect 0, 


PodgroupEnable 


01 


(Phases 


A 


and 


B) 


ChromapodSelect 1 , NozzIeSelect 0, 


PodgroupEnable 


10 


(Phases 


A 


and 


B) 


ChromapodSelect 3, NozzIeSelect 9, 


PodgroupEnable 


01 


(Phases 


A 


and 


B) 


ChromapodSelect 3, NozzIeSelect 9, 


PodgroupEnable 


10 


(Phases 


A 


and 


B) 


ChromapodSelect 4, NozzIeSelect 9, 


PodgroupEnable 


01 


(Phases 


A 


and 


B) 


ChromapodSelect 4, NozzIeSelect 9, 


PodgroupEnable 


10 


(Phases 


A 


and 


B) 



When a nozzle fires, it takes approximately 100u.s to refill. The nozzle cannot be fired 
before this refill time has elapsed. This limits the fastest printing speed to 1 00u.s per line. 
In the high-speed print mode, the time to print a line is lOOus, so the time between firing a 
nozzle from one line to the next matches the refill time. The low-speed print mode is 
slower than this, so is also acceptable. 

The firing of a nozzle also causes acoustic perturbations for a limited time within the com- 
mon ink reservoir of that nozzle's pod. The perturbations can interfere with the firing of 
another nozzle within the same pod. Consequently, the firing of nozzles within a pod 
should be offset from each other as long as possible. We therefore fire four nozzles from a 
chromapod (one nozzle per color) and then move onto the next chromapod within the pod- 
group. 

• In the low-speed printing mode the podgroups are fired separately. Thus the 5 chroma- 
pods within both podgroups must all fire before the first chromapod fires again, total- 
ling 10 x 2u.s cycles. Consequently each pod is fired once per 20u.s. 

• In the high-speed printing mode, the podgroups are fired together. Thus the 5 chroma- 
pods within a single podgroups must all fire before the first chromapod fires again, 
totalling 5 x 2jlis cycles. Consequently each pod is fired once per 10 jas. 

As the ink channel is 300u.m long and the velocity of sound in the ink is around 1 500m/s, 
the resonant frequency of the ink channel is 2.5 MHz. Thus the low-speed mode allows 50 
resonant cycles for the acoustic pulse to dampen, and the high-speed mode allows 25 reso- 
nant cycles. Consequently any acoustic interference is minimal in both cases. 
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14.1.3 Feedback from a Segment 

A segment produces several lines of feedback. The feedback lines are used to adjust the 
timing of the firing pulses. Since multiple segments are collected together into a printhead, 
it is effective to share the feedback lines as a tri-state bus, with only one of the segments 
placing the feedback information on the feedback lines. 

A pulse on the segment's SenseSegSelect line ANDed with data on ColorlData selects if 
the particular segment will provide the feedback. The feedback sense lines will come from 
that segment until the next SenseSegSelect pulse. The feedback sense lines are as follows: 

• Tsense informs the controller how hot the printhead is. This allows the controller to 
adjust timing of firing puises, since temperature affects the viscosity of the ink. 

• Vsense informs the controller how much voltage is available to the actuator. This 
allows the controller to compensate for a flat battery or high voltage source by adjust- 
ing the pulse width. 

• Rsense informs the controller of the resistivity (Ohms per square) of the actuator 
heater. This allows the controller to adjust the pulse widths to maintain a constant 
energy irrespective of the heater resistivity. 

• Wsense informs the controller of the width of the critical part of the heater, which may 
vary up to ± 5% due to lithographic and etching variations. This allows .he controller 
to adjust the pulse width appropriately. 

14.1.4 Preheat Cycle 

The printing process has a strong tendency to stay at the equilibrium temperature. To 
ensure that the first section of the printed photograph has a consistent dot size, the equilib- 
rium temperature must be met before printing any dots. This is accomplished via a preheat 
cycle. 

The Preheat cycle involves a single Load Cycle to all nozzles of a segment with Is (i.e. 
setting all nozzles to fire), and a number of short firing pulses to each nozzle. The duration 
of the pulse must be insufficient to fire the drops, but enough to heat up the ink. Altogether 
about 200 pulses for each nozzle are required, cycling through in the same sequence as a 
standard Print Cycle. 

Feedback during the Preheat mode is provided by Tsense, and continues until equilibrium 
temperature is reached (about 30° C above ambient). The duration of the Preheat mode is 
around 50 milliseconds, and depends on the ink composition. 

Preheat is performed before each print job. This does not affect performance as it is done 
while the data is being transferred to the printer. 

1 4.1 .5 Cleaning Cycle 

In order to reduce the chances of nozzles becoming clogged, a cleaning cycle can be 
undertaken before each print job. Each nozzle is fired a number of times into an absorbent 
sponge. 

The cleaning cycle involves a single Load Cycle to all nozzles of a segment with Is (i.e. 
setting all nozzles to fire), and a number of firing pulses to each nozzle. The nozzles are 
cleaned via the same nozzle firing sequence as a standard Print Cycle. The number of 
times that each nozzle is fired depends upon the ink composition and the time that the 
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printer has ben idle. As with preheat, the cleaning cycle has no effect on printer perfor- 
mance. 



14.1.6 Printhead Interface Summary 

Each segment has the following connections to the bond pads: 

Table 12. Segment Interface Connections 



Chroma pod Select 


3 


Select which chromapod will fire (0-4) 


NozzteSelect 


4 


Select which nozzle from the pod will fire (0-9* 


PodgroupEnable 


2 


Enable the podgroups to fire (choice of: 01 , 10, 11) 


AEnable 


1 


Firing pulse for podgroup A 


BEnable 


1 


Firing pulse for podgroup B 


ColorNData 




Input to shift registers (1 bit for each of C colors in the segment) 


SRCIock 




A pulse on SRCIock (ShiftRegisterClock) loads C bits from Color- 
Data into the C shift registers. 


PTransfer 




Parallel transfer of data from the shift registers to the internal 
NozzleEnable bits (one per nozzle). 


SenseSegSeiect 




A pulse on SenseSegSeiect ANDed with data on Colon Data 
selects the sense lines for this segment. 


Tsense 




Temperature sense 


Vsense 




Voltage sense 


Rsense 




Resistivity sense 


Wsense 




Width sense 


Logic GND 




Logic ground 


Logic PWR 




Logic power 


V- 


21 


Actuator Ground 


V+ 


21 


Actuator Power 


TOTAL 


62+C 


(if C is 4, Total = 66) 
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14,2 Making Memjet Printheads out of Segments 

A Memjet printhead is composed of a number of identical 1/2 inch printhead segments. 
These 1/2 inch segments are manufactured together or placed together after manufacture 
to produce a printhead of the desired length. Each 1/2 inch segments prints 800 1600 dpi 
bi-level dots in up to 4 colors over a different part of the page to produce the final image. 
Although each segment produces 800 dots of the final image, each dot is represented by a 
combination of colored inks. 

A 4-inch printhead, for example, consists of 8 segments, typically manufactured as a 
monolithic printhead. In a typical 4-color printing application (cyan, magenta, yellow, 
black), each of the segments prints bi-level cyan, magenta, yellow and black dots over a 
different part of the page to produce the final image. The positions of the segments are 
shown in Figure 46. 



Paper 




Figure 46. Arrangement of Segments in a 4-inch Printhead 

An 8- inch printhead can be constructed from two 4-inch printheads or from a single 8-inch 
printhead consisting of 16 segments. Regardless of the construction mechanism, the effec- 
tive printhead is still 8 inches in length. 

A 2-inch printhead has a similar arrangement, but only uses 4 segments. Likewise, a 
full-bleed A4/Letter printer uses 1 7 segments for an effective 8V2" printing area. 

Since the total number of nozzles in a segment is 800C (see Table 10), the total number of 
nozzles in a given printhead with S segments is 800CS. Thus segment N is responsible for 
printing dots 800N to 800N+799. 

A number of considerations must be made when wiring up a printhead. As the width of the 
printhead increases, the number of segments increases, and the number of connections 
also increases. Each segment has its own ColorData connections (C of them), as well as 
SRClock and other connections for loading and printing. 
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14.2.1 Loading Considerations 

When the number of segments S is small it is reasonable to load all the segments simulta- 
neously by using a common SRClock line and placing C bits of data on each of the Color- 
Data inputs for the segments. In a 4-inch printer, S=8, and therefore the total number of 
bits to transfer to the printhead in a single SRClock pulse is 32. However for an 8-inch 
printer, S=16, and it is unlikely to be reasonable to have 64 data lines running from the 
print data generator to the printhead. 

Instead, it is convenient to group a number of segments together for loading purposes. 
Each group of segments is small enough to be loaded simultaneously, and share an 
SRClock. For example, an 8-inch printhead can have 2 segment groups, each segment 
group containing 8 segments. 32 ColorData lines can be shared tor both groups, with 2 
SRClock lines, one per segment group. 

When the number of segment groups is not easily divisible, it is still convenient to group 
the segments. One example is a 8/2" printer for producing A4/Letter pages. There are 17 
segments, and these can be grouped as two groups of 9 (9C bits of data going to each seg- 
ment, with all 9C bits used in the first group, and only 8C bits used for the second group), 
or as 3 groups of 6 (again, C bits are unused in the last group). 

As the number of segment groups increases, the time taken to load the printhead increases. 
When there is only one group, 800 load pulses are required (each pulse transfers C data 
bits). When there are G groups, 800G load pulses are required. The bandwidth of the con- 
nection between the data generator and the printhead must be able to cope and be within 
the allowable timing parameters for the particular application. 

If G is the number of segment groups, and L is the largest number of segments in a group, 
the printhead requires LC ColorData lines and G SRClock lines. Regardless of G, only a 
single PTransfer line is required - it can be shared across all segments. 

Since L segments in each segment group are loaded with a single SRClock pulse, any 
printing process must produce the data in the correct sequence for the printhead. As an 
example, when G=2 and L=4, the first SRClock 1 pulse will transfer the ColorData bits for 
the next Print Cycle's dot 0, 800, 1600, and 2400. The first SRCIock2 pulse will transfer 
the ColorData bits for the next Print Cycle's dot 3200, 4000, 4800, and 5600. The second 
SRClock 1 pulse will transfer the ColorData bits for the next Print Cycle's dot 1, 801, 
1 60 1 , and 240 1 . The second SRClock2 pulse will transfer the ColorData bits for the next 
Print Cycle's dot 320 1 , 400 1 , 480 1 and 560 1 . 

After 800G SRClock pulses (800 to each of SRClock I and SRClock2), the entire line has 
been loaded into the printhead, and the common PTransfer pulse can be given. 

It is important to note that the odd and even color outputs, although printed during the 
same Print Cycle, do not appear on the same physical output line. The physical separation 
of odd and even nozzles within the printhead, as well as separation between nozzles of dif- 
ferent colors ensures that they will produce dots on different lines of the page. This rela- 
tive difference must be accounted for when loading the data into the printhead. The actual 
difference in lines depends on the characteristics of the inkjet mechanism used in the print- 
head. The differences can be defined by variables D, and D 2 where D, is the distance 
between nozzles of different colors, and D 2 is the distance between nozzles of the same 
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color. Considering only a single segment group, Table 13 shows the dots transferred to 
segment n of a printhead during the first 4 pulses of the shared SRClock. 

Table 13. Order of Dots Transferred to a Segment in a Printhead 



f|||p| 












1 




800S a 


N 


N+D^ 




2 




800S+1 


N+D 2 C 




N+CC-IJDj+Ds 


3 




800S+2 


N 


N+D 1 


N+CC-^Dt 


4 




800S+3 


N+D 2 


N+D-,+D 2 


N+CC-IJD^Da 



a. S = segment number 

b. 0) = number of lines between the nozzles of one color and the next (likely = 4-8) 

c. D 2 = number of lines between two rows of nozzles of the same color {likely = 1) 

And so on for all 800 SRClock pulses to the particular segment group. 



14.2.2 Printing Considerations 

With regards to printing, we print 4C nozzles from each segment in the low-speed printing 
mode, and 8C nozzles from each segment in the high speed printing mode. 

While it is certainly possible to wire up segments in any way, this document only consid- 
ers the situation where all segments fire simultaneously. This is because the low-speed 
printing mode allows low-power printing for small printheads (e.g. 2-inch and 4-inch), 
and the controller chip design assumes there is sufficient power available for the large 
print sizes (such as 8-18 inches). It is a simple matter to alter the connections in the print- 
head to allow grouping of firing should a particular application require it. 

When all segments are fired at the same time 4CS nozzles are fired in the low-speed print- 
ing mode and 8CS nozzles are fired in the high-speed printing mode. Since all segments 
print simultaneously, the printing logic is the same as defined in Section 14.1.2.2 on page 
58. 

The timing for the two printing modes is therefore: 

• 200 \is to print a line at low speed (comprised of 1 00 2u,s cycles) 

• 100 [is to print a line at high speed (comprised of 50 2(is cycles) 



14.2.3 Feedback Considerations 

A segment produces several lines of feedback, as defined in Section 14. 1. 3 on page 61. 
The feedback lines are used to adjust the timing of the firing pulses. Since multiple seg- 
ments are collected together into a printhead, it is effective to share the feedback lines as a 
tri-state bus, with only one of the segments placing the feedback information on the feed- 
back lines at a time. 

Since the selection of which segment will place the feedback information on the shared 
Tsense, Vsense, Rsense, and Wsense lines uses the ColorlData line, the groupings of seg- 
ments for loading data can be used for selecting the segment for feedback. 
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Just as there are G SRC lock lines (a single line is shared between segments of the same 
segment group), there are G SenseSegSelect lines shared in the same way. When the cor- 
rect SenseSegSelect line is pulsed, the segment of that group whose ColorlData bit is set 
will start to place data on the shared feedback lines. The segment previously active in 
terms of feedback must also be disabled by having a 0 on its Colorl Data bit, and this seg- 
ment may be in a different segment group. Therefore when there is more than one segment 
group, changing the feedback segment requires two steps: disabling the old segment, and 
enabling the new segment. 

14.2.4 Printhead Connection Summary 

This section assumes that a printhead has been constructed from a number of segments as 
described in the previous sections. It assumes that for data loading purposes, the segments 
have been grouped into G segment groups, with L segments in the largest segment group. 
It assumes there are C colors in the printhead. It assumes that the firing mechanism for the 
printhead is that all segments fire simultaneously, and only one segment at a time places 
feedback information on a common tri-state bus. Assuming ail these things, Table 14 lists 
the external connections that are available from a printhead: 



Table 14. Printhead Connections 









ChromapodSelect 


3 


Select which chromapod wilt fire (0-4) 


NozzleSefect 


4 


Select which nozzle from the pod will fire (0-9) 


PodgroupEnable 


2 


Enable the podgroups to fire (choice of: 01, 10, 11) 


AEnable 


1 


Firing pulse for phasegroup A 


BEnable 


1 


Firing pulse for phasegroup B 


ColorData 


CL 


Inputs to C shift registers of segments 0 to L-1 


SRCIock 


G 


A pulse on SRCIock[N] (ShiftRegisterClock N) loads the current 
values from ColorData lines into the L segments in segment 
group N. 


PTransfer 


1 


Parallel transfer of data from the shift registers to the internal 
NozzleEnable bits (one per nozzle). 


SenseSegSelect 


G 


A pulse on SenseSegSelect N ANDed with data on 

Colorl Data[n] selects the sense lines for segment n in segment 

group N. 


Tsense 




Temperature sense 


Vsense 




Voltage sense 


Rsense 




Resistivity sense 


Wsense 




Width sense 


Logic GND 




Logic ground 


Logic PWR 




Logic power 


V- 


Bus 
bars 


Actuator Ground 


V+ 


Actuator Power 


TOTAL 


18+2G+CL 
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15 Memjet Printhead Interface 

The printhead interface (PHI) is the means by which the processor loads the Memjet print- 
head with the dots to be printed, and controls the actual dot printing process. The PHI con- 
tains: 

• a LineSyncGen unit (LSGU), which provides synchronization signals for multiple 
chips (allows side-by-side printing and front/back printing) as well as stepper motors. 

• a Memjet interface (MJI), which transfers data to the Memjet printhead, and controls 
the nozzle firing sequences during a print. 

• a line loader/format unit (LLFU) which loads the dots for a given print line into local 
buffer storage and formats them into the order required for the Memjet printhead. 

The units within the PHI are controlled by a number of registers that are programmed by 
the processor. In addition, the processor is responsible for setting up the appropriate 
parameters in the DMA controller for the transfers from memory to the LLFU. This 
includes loading white fall O's) into appropriate colors during the start and end of a page 
so that the page has clean edges. 

The PHI is capable of dealing with a variety of printhead lengths and formats. In terms of 
broad operating customizations, the PHI is parameterized as follows: 



Table 15. Basic Printing Parameters 









MaxCoiors 


No of Colors in printhead 


1-4 


SegmentsPerXfer 


No of segments written to per transfer. Is equal to the 
number of segments in the largest segment group 


1-9 


SegmentGroups 


No of segment groups in printhead 


1-4 



The internal structure of the PHI allows for a maximum of 4 colors, 9 segments per trans- 
fer, and 4 transfers. Transferring 4 colors to 9 segments is 36 bits per transfer, and 4 trans- 
fers to 9 segments equates to a maximum printed line length of 18 inches. The total 
number of dots per line printed by an 1 8-inch 4 color printhead is 115,200 (18 x 1600x4). 



Other example settings are shown in Table 1 6: 
Table 16. Example Settings for Basic Printing Parameters 
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15.1 Block Diagram of Printhead Interface 

The internal structure of the Printhead Interface is shown in Figure 47. 
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Figure 47. Internal Structure of Printhead Interface 

In the PHI there are two LSGUs. The first LSGU produces LineSyncO, which is used to 
control the Memjet Interface in all synchronized chips. The second LSGU produces 
LineSyncI which is used to pulse the paper drive stepper motor. 

The Master/Slave pin on the chip allows multiple chips to be connected together for 
side-by-side printing, front/back printing etc. via a Master/Slave relationship. When the 
Master/Slave pin is attached to V DD , the chip is considered to be the Master, and LineSync 
pulses generated by the two LineSyncGen units are enabled onto the two tri-state Line- 
Sync common lines (LineSyncO and LineSyncI, shared by all the chips). When the Mas- 
ter/Slave pin is attached to GND, the chip is considered to be the Slave, and LineSync 
pulses generated by the two LineSyncGen units are not enabled onto the common Line- 
Sync lines. In this way, the Master chip's LineSync pulses are used by all PHls on all the 
connected chips. 

The following sections detail the LineSyncGen Unit, the Line Loader/Format Unit and 
Memjet Interface respectively. 



1 5.2 LineSyncGen Unit 

The LineSyncGen units (LSGU) are responsible for generating the synchronization pulses 
required for printing a page. Each LSGU produces an external LineSync signal to enable 
line synchronization. The generator inside the LGSU generates a LineSync pulse when 
told to 4 go\ and then every so many cycles until told to stop. The LineSync pulse defines 
the start of the next line. 

The exact number of cycles between LineSync pulses is determined by the CyclesBetween- 
Pulses register, one per generator. It must be at least long enough to allow one line to print 
(100 jis or 200 |is depending on whether the speed is low or high) and another line to load, 
but can be longer as desired (for example, to accommodate special requirements of paper 
transport circuitry). If the CyclesBetweenPulses register is set to a number less than a line 
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print time, the page will not print properly since each LineSync pulse will arrive before the 
particular line has finished printing. 

The following interface registers are contained in the LSGU: 
Table 17. LineSyncGen Unit Registers 



CyclesBetweenPulses 


The number of cycles to wait between generating one Line- 
Sync pulse and the next. 


Go 


Controls whether the LSGU is currently generating LineSync 
pulses or not. 

A write of 1 to this register generates a LineSync pulse, 
transfers CyclesBetweenPulses to CydesRemaining, and 
starts the countdown. When CydesRemaining hits 0, another 
LineSync pulse is generated, CyclesBetweenPulses is trans- 
ferred to CydesRemaining and the countdown is started 
again. 

A write of 0 to this register stops the countdown and no more 
LineSync pulses are generated. 


CydesRemaining 


A status register containing the number of cycles remaining 
until the next LineSync puise is generated. 



The LineSync pulse is not used directly from the LGSU. The LineSync pulse is enabled 
onto a tri-state LineSync line only if the Master/Slave pin is set to Master. Consequently 
the LineSync pulse is only used in the form as generated by the Master chip (pulses gener- 
ated by Slave chips are ignored). 



15.3 Memjet Interface 

The Memjet interface (MJ1) transfers data to the Memjet printhead, and controls the noz- 
zle firing sequences during a print. 

The MJI is simply a State Machine (see Figure 48) which follows the printhead loading 
and firing order described in Section 14.2.1 on page 64, Section 14.2.2 on page 65, and 
includes the functionality of the Preheat Cycle and Cleaning Cycle as described in Section 
14. 1 .4 on page 6 1 and Section 14. 1 .5 on page 6 1 . Both high-speed and low-speed printing 
modes are available, although the MJI always fires a given nozzle from all segments in a 
printhead simultaneously (there is no separate firing of nozzles from one segment and then 
others). Dot counts for each color are also kept by the MJI. 

The MJI loads data into the printhead from a choice of 2 data sources: 

• All Is. This means that all nozzles will fire during a subsequent Print cycle, and is the 
standard mechanism for loading the printhead for a preheat or cleaning cycle. 

♦ From the 36-bit input held in the Transfer register of the LLFU. This is the standard 
means of printing an image. The 36-bit value from the LLFU is directly sent to the 
printhead and a 1-bit 'Advance* control pulse is sent to the LLFU. 

The MJI knows how many lines it has to print for the page. When the MJI is told to 'go', it 
waits for a LineSync pulse before it starts the first line. Once it has finished loading/print- 
ing a line, it waits until the next LineSync pulse before starting the next line. The MJI 
stops once the specified number of lines has been loaded/printed, and ignores any further 
LineSync pulses. 
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The MJI is therefore directly connected to the LLFU, LineSyncO (shared between all syn- 
chronized chips), and the external Memjet printhead. The basic structure is shown in Fig- 
ure 48. 



LineSyncO 



LLFU 


36 

^ ► 


State 
Machine 





1 




Figure 48. Memjet Interface 

The MJI accepts 36 bits of data from the LLFU. Of these 36 bits, only the bits correspond- 
ing to the number of segments and number of colors will be valid. For example, if there 
are only 2 colors and 9 segments, bits 0-1 will be valid for segment 0, bits 2-3 will be 
invalid, bits 4-5 will be valid for segment 1, bits 6-7 will be invalid etc. The state machine 
does not care which bits are valid and which bits are not valid - it merely passes the bits 
out to the printhead. The data lines and control signals coming out of the MJI can be wired 
appropriately to the pinouts of the chip, using as few pins as required by the application 
range of the chip (see Section 15.3.1 on page 70 for more information). 

15,3.1 Connections to Printhead 

The MJI has a number of connections to the printhead, including a maximum of 4 colors, 
clocked in to a maximum of 9 segments per transfer to a maximum of 4 segment groups. 
The lines coming from the MJI can be directly connected to pins on the chip, although not 
all lines will always be pins. For example, if the chip is specifically designed for only con- 
necting to 8 inch CMYK printers, only 32 bits of data need to be transferred each transfer 
pulse. Consequently 32 pins of data out (8 pins per color), and not 36 pins are required. In 
the same way, only 2 SRClock pulses are required, so only 2 pins instead of 4 pins are 
required to cater for the different SRClocks. And so on. 

If the chip must be completely generic, then all connections from the MJI must be con- 
nected to pins on the chip (and thence to the Memjet printhead). 

Table 18 lists the maximum connections from the MJI, many of which are always con- 
nected to pins on the chip. Where the number of pins is variable, a footnote explains what 
the number of pins depends upon. The sense of input and output is with respect to the MJI. 
The names correspond to the pin connections on the printhead. 



Table 18. Memjet Interface Connections 





llliil 






Chromapod Select 


3 


o 


Select which chromapod will fire (0-4) 


NozzteSelect 


4 


o 


Select which nozzle from the pod will fire (0-9) 


PodgroupEnable 


2 


o 


Enable the podg roups to fire (choice of: 01 , 10, 11) 


AEnable 


1 


o 


Firing pulse for podg roup A. In the current design all 
segments fire simultaneously, although multiple AEnable 
lines could be added for dividing the firing sequence 
over multiple segment groups for reasons of power and 
speed. 
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Table 18. Memjet Interface Connections 



BEnable 


1 


O 


Firing pulse for podgroup B. In the current design all 
segments fire simultaneously, although multiple BEnable 
lines could be added for dividing the firing sequence 
over multiple segment groups for reasons of power and 
speed. 


Colon Data[0-8] 


9 a 


O 


Output to Colon Data shift register of segments 0-8 


Color2Data[0-8] 


9 b 


O 


Output to Color2Data shift register of segments 0-8 


Color3Data[0-8] 


S c 


O 


Output to Color3Data shift register of segments 0-8 


Color4Data[0-8] 


9 d 


o 


Output to Color4Data shift register of segments 0-8 


SRCIock[1-4] 


4 e 


o 


A pulse on SRCIockfN] (ShrftRegisterClock) loads the 
current values from Color1Data[0-8], Color2Data[0-8], 
Color3Data[0-8] and Color4Data[0-8] into the segment 
group N on the printhead. 


PTransfer 


1 


o 


Parallel transfer of data from the shift registers to the 
printhead's internal NozzleEnable bits (one per nozzle). 


SenseSegSelect[1-4] 


4 f 


o 


A pulse on SenseSegSelect[N] ANDed with data on 
Colon Data[n] enables the sense lines for segment n in 
segment group N of the printhead. 


Tsense 


1 


I 


Temperature sense 


Vsense 


1 


I 


Voltage sense 


Rsense 


1 


I 


Resistivity sense 


Wsense 


1 


I 


Width sense 


TOTAL 


52 







d. 



Although 9 lines are available from the MJI, the number of pins coming from the chip will only 
reflect the actual number of segments in a segment group. The pins for Colon Data are man- 
datory, since each printhead must print in at feast 1 color. 

These lines are only translated into pins if the chip is to control a printhead with at least 2 col- 
ors. Although 9 lines are available from the MJI, the number of pins coming from the chip for 
Color2Data will only reflect the actual number of segments in a segment group. 
These lines are only translated into pins if the chip is to control a printhead with at least 3 col- 
ors. Although 9 lines are available from the MJI, the number of pins coming from the chip for 
Color3Data will only reflect the actual number of segments in a segment group: 
These lines are only translated into pins if the chip is to control a printhead with 4 colors. 
Although 9 lines are available from the MJI, the number of pins coming from the chip for 
Color4Data will only reflect the actual number of segments in a segment group. 
Although 4 lines are available from the MJI, the number of pins coming from the chip will only 
reflect the actual number of segment groups. A minimum of 1 pin is required since there is at 
least 1 segment group (the entire printhead). 

Although 4 lines are available from the MJI, the number of pins coming from the chip will only 
reflect the actual number of segment groups. A minimum of 1 pin is required since there is at 
least 1 segment group (the entire printhead). 



15.3.2 Firing Pulse Duration 

The duration of firing pulses on the AEnable and BEnable lines depend on the viscosity of 
the ink (which is dependant on temperature and ink characteristics) and the amount of 
power available to the printhead. The typical pulse duration range is 1.3 to 1.8 U-S. The MJI 
therefore contains a programmable pulse duration table, indexed by feedback from the 
printhead. The table of pulse durations allows the use of a lower cost power supply, and 
aids in maintaining more accurate drop ejection. 

The Pulse Duration table has 256 entries, and is indexed by the current Vsense and Tsense 
settings. The upper 4-bits of address come from Vsense, and the lower 4-bits of address 
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come from Tsense. Each entry is 8 bits, and represents a fixed point value in the range of 
0-4u.s. The process of generating the AEnable and BEnable lines is shown in Figure 49. 
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(non-linear) 



4 



Load Table 
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Duration 

Table 
(256x8) 



Pulse Width 
Generator 



_ AEnable 
BEnable 



Figure 49. Generation of AEnable and BEnable Pulse Widths 

The 2 5 6- byte table is written by the CPU before printing the first page. The table may be 
updated in between pages if desired. Each 8-bit pulse duration entry in the table combines: 



User brightness settings (from the page description) 

Viscosity curve of ink (from the QA Chip) 

Rsense 

Wsense 

Vsense 

Tsense 



15.3.3 Dot Counts 

The MJ1 maintains a count of the number of dots of each color fired from the printhead. 
The dot count for each color is a 32-bit value, individually cleared under processor con- 
trol. At 32-bits length, each dot count can hold a maximum coverage dot count of 17 
8-inch x 12-inch pages, although in typical usage, the dot count will be read and cleared 
after each page or half-page. 

The dot counts are used by the processor to update the QA chip in order to predict when 
the ink cartridge runs out of ink. The processor knows the volume of ink in the cartridge 
for each of the colors from the QA chip. Counting the number of drops eliminates the need 
for ink sensors, and prevents the ink channels from running dry. An updated drop count is 
written to the QA chip after each page. A new page will not be printed unless there is 
enough ink left, and allows the user to change the ink without getting a dud half-printed 
page which must be reprinted. 
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The layout of the dot counter for Color I is shown in Figure 50. The remaining 3 dot 
counters (Color IDotCount, Color2DotCount, and Color3DotCount) are identical in struc- 
ture. 



SRCIock[1^] 



ClearCount 



Colon Data . 



9 line to 4 

line 
encoder 



4 




32 



^Load "V Clea r 



32-bit Colorl DotCount 



32 
y 



32 



Figure 50. Dot Count Logic 



15.3.4 Registers 

The processor communicates with the MJI via a register set. The registers allow the pro- 
cessor to parameterize a print as well as receive feedback about print progress. 

The following registers are contained in the MJI: 



Table 19. Memjet Interface Registers 







Print Parameters 


SegmentsPerXfer 


The number of segments to write to each transfer. This also equals 
the number of cycles to wait between each transfer (before generating 
the next Advance pulse). Each transfer has MaxColors x Seg- 
mentsPerXfer valid bits. 


SegmentG roups 


The number of segment groups in the printhead. This equals the num- 
ber of times that SegmentsPerXfer cycles must elapse before a single 
dot has been written to each segment of the printhead. The MJI does 
this 800 times to completely transfer all the data for the line to the 
printhead. 


PrintSpeed 


Whether to print at low or high speed (determines the value on the 
PodgroupEnable lines during the print). 


NumLines 


The number of Load/Print cycles to perform. 


Monitoring the Print (read only from point of view of processor) 


Status 


The Memjet Interface's Status Register 


LinesRemaining 


The number of lines remaining to be printed. Only valid while Go=1. 
Starting value is NumLines and counts down to 0. 


TransfersRemaining 


The number of sets of SegmentGroups transfers remaining before the 
Printhead is considered loaded for the current line. Starts at 800 and 
counts down to 0. Only valid while Go=1 . 


SegGroupsRemaining 


The number of segment groups remaining in the current set of trans- 
fers of 1 dot to each segment Starts at SegmentGroups and counts 
down to 0. Only valid while Go=1. 


SenseSegment 


The 9-bit value to place on the Colon Data lines during a subsequent 
feedback SenseSegSelect pulse. Only 1 of the 9 bits should be set, 
corresponding to one of the (maximum) 9 segments. See SenseSe- 
tect for how to determine which of the segment groups to sense. 
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Table 19. Memjet Interface Registers 







SetAllNozzles 


If non-zero, the 36-bit value written to the printhead during the Load- 
Dots process is ail 1s, so that all nozzles will be fired during the subse- 
quent PrintDots process. This is used during the preheat and cleaning 
cycles. 

If 0, the 36-bit value written to the printhead comes from the LLFU. 
This is the case during the actual printing of regular images. 


Actions 


Reset 


A write to this register resets the MJI, stops any loading or printing 
processes, and loads ail registers with 0. 


SenseSelect 


A write to this register with any value clears the FeedbackValid bit of 
the Status register, and the remaining action depends on the values in 
the LoadingDots and PrintingDots status bits. 

If either of the status bits are set, the Feedback bit is l Tared and noth- 
ing more is done. 

If both status bits are clear, a pulse is given simultaneously on all 4 
SenseSegSelect lines with all ColorData bits 0. This stops any exist- 
ing feedback. Depending on the two low-order bits written to Sense- 
Select register, a pulse is given on SenseSegSelectl , 
SenseSegSelect2, SenseSegSelect3, or SenseSegSe!ect4 line, with 
the ColorlData bits set according to the SenseSegment register. 
Once the various sense lines have been tested, the values are placed 
in the Tsense, Vsense, Rsense, and Wsense registers, and the Feed- 
back bit of the Status register is set. 


Go 


A write of 1 to this bit starts the LoadDots / PrintDots cycles, which 
commences with a wait for the first LineSync pulse. A total of Num- 
Lines lines are printed, each line being loaded/printed after the receipt 
of a LineSync pulse. The loading of each line consists of Segment- 
Groups 36-bit transfers. As each line is printed, LinesRemaining dec- 
rements, and TransfersRemaining is reloaded with SegmentGroups 
again. The status register contains print status information. Upon com- 
pletion of NumLines, the loading/printing process stops, the Go bit is 
cleared, and any further LineSync pulses are ignored. During the final 
print cycle, nothing is loaded into the printhead. 

A write of 0 to this bit stops the print process, but does not clear any 
other registers. 


ClearCounts 


A write to this register clears the ColorlDotCount, Cotor2DotCount, 
Color3DotCount, and Color4DotCount registers if bits 0, 1, 2, or 3 
respectively are set Consequently a write of 0 has no effect. 


Feedback 


Tsense 


Read only feedback of Tsense from the last SenseSegSelect pulse 
sent to segment SenseSegment. Is only valid if the FeedbackValid bit 
of the Status register is set. 


Vsense 


Read only feedback of Vsense from the last SenseSegSelect pulse 
sent to segment SenseSegment. Is only valid if the FeedbackValid bit 
of the Status register is set. 


Rsense 


Read only feedback of Rsense from the last SenseSegSelect pulse 
sent to segment SenseSegment. Is only valid if the FeedbackValid bit 
of the Status register is set. 


Wsense 


Read only feedback of Wsense from the last SenseSegSelect pulse 
sent to segment SenseSegment. Is only valid if the FeedbackValid bit 
of the Status register is set. 


ColorlDotCount 


Read only 32-bit count of colon dots sent to the printhead: 


Color2DotCount 


Read only 32-bit count of color2 dots sent to the printhead. 



Confidential 



7 September 1999 



74 



Silverbrook Research 



Netpage Printer Design Description 



draft vO. 3 



Table 19. Memjet Interface Registers 





' - ' . ' - . 


Color3DotCount 


Read only 32-bit count of color3 dots sent to the printhead 


Color4DotCount 


Read only 32-bit count of color4 dots sent to the printhead 



The MJI's Status Register is a 16-bit register with bit interpretations as follows: 
Table 20. MJI Status Register 



LoadingDots 


1 


If set the MJI is currently loading dots, with the number of dots 
remaining to be transferred in TransfersRemaining. 

If clear, the MJI is not currently loading dots 


PrintingDots 


1 


If set, the MJI is currently printing dots. 

If clear, the MJI is not currently printing dots. 


PrintingA 


1 


This bit is set while there is a pulse on the AEnable line 


PrintingB 


1 


This bit is set while there is a pulse on the BEnable line 


FeedbackValid 


1 


This bit is set while the feedback values Tsense, Vsense, 
Rsense, and Wsense are valid. 


Reserved 


3 




PrintingChromapod 


4 


This holds the current chromapod being fired while the 
PrintingDots status bit is set. 


PrintingNozzies 


4 


This holds the current nozzle being fired while the 
PrintingDots status bit is set. 



The following pseudocode illustrates the logic required to load a printhead for a single 
line. Note that loading commences only after the LineSync pulse arrives. This is to ensure 
the data for the line has been prepared by the LLFU and is valid for the First transfer to the 
printhead. 



Wait for LineSync 

For TransfersRemaining = 800 to 0 
For I = 0 to SegmentGroups 
If (SetAllNozzles) 

Set all ColorData lines to be 1 
Else 

Place 36 bit input on 36 ColorData lines 
Endlf 

Pulse SRClock[I] 
Wait Segments PerXfer cycles 
Send ADVANCE signal 
EndFor 
EndFor - 
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15.3.5 Preheat and Cleaning Cycles 

The Cleaning and Preheat cycles are simply accomplished by setting appropriate registers 
in the MJI: 

• SetAliNozzles = 1 

• Set the PulseDuration register to either a low duration (in the case of the preheat mode) 
or to an appropriate drop ejection duration for cleaning mode. 

• Set NumLines to be the number of times the nozzles should be fired 

• Set the Go bit and then wait for the Go bit to be cleared when the print cycles have 
completed. 

The LSGU must also be programmed to send LineSync pulses at the correct frequency. 



15.4 Line Loader/Format Unit 

The line loader/format unit (LLFU) loads the dots for a given print line into local buffer 
storage and formats them into the order required for the Memjet printhead. it is responsi- 
ble for supplying the pre-calculated nozzleEnable bits to the Memjet interface for the 
eventual printing of the page. 



The printing uses a double buffering scheme for preparing and accessing the dot-bit infor- 
mation. While one line is being loaded into the first buffer, the pre-loaded line in the sec- 
ond buffer is being read in Memjet dot order. Once the entire line has been transferred 
from the second buffer to the printhead via the Memjet interface, the reading and writing 
processes swap buffers. The first buffer is now read and the second buffer is loaded up 
with the new line of data. This is repeated throughout the printing process, as can be seen 
in the conceptual overview of Figure 5 1 . 
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Figure 51. Conceptual Overview of Double Buffering 
During Print Lines N and N+1 

The size of each buffer is HKBytes to cater for the maximum line length of 18 inches in 4 
colors (18 x 1600 x 4 bits = 1 15,200 bits = 14,400 bytes). The size for both Buffer 0 and 
Buffer 1 is 28.128 KBytes. While this design allows for a maximum print length of 18 
inches, it is trivial to reduce the buffer size to target a specific application. 
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The actual implementation of the LLFU is shown in Figure 52. Since one buffer is being 
read from while the other is being written to, two sets of address lines must be used. The 
32-bits Dataln from the common data bus are loaded depending on the WriteEnables, 
which are generated by the State Machine in response to the DMA Acknowledges. 
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Figure 52. Structure of LLFU 

A multiplexor chooses between the two 4-bit outputs of Buffer 0 and Buffer 1 , and sends 
the result to a 9-entry by 4-bit shift register. After a maximum of 9 read cycles (the number 
depends on the number of segments written to per transfer), and whenever an Advance 
pulse comes from the MJI, the current 36-bit value from the shift register is gated into the 
36-bit Transfer register, where it can be used by the MJI. 

Note that not all the 36 bits are necessarily valid. The number of valid bits of 36 depends 
on the number of colors in the printhead, the number of segments, and the breakup of seg- 
ment groups (if more than one segment group). For more information, see Section 14.2 on 
page 63. 

A single line in an L-inch C-color printhead consists of 1600L C-color dots. At 1 bit per 
colored dot, a single print-line consists of 1600 LC bits. The LLFU is capable of address- 
ing a maximum line size of 18 inches in 4 colors, which equates to 108,800 bits (14 
KBytes) per line. These bits must be supplied to the MJI in the correct order for being sent 
on to the printhead. See Section 14.2.1 on page 64 for more information concerning the 
Load Cycle dot loading order, but in summary, 2LC bits are transferred to the printhead in 
SegmentG roups transfers, with a maximum of 36 bits per transfer. Each transfer to a par- 
ticular segment of the printhead must load all colors simultaneously. 
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15.4.1 Buffers 

Each of the two buffers is broken into 4 sub-buffers, 1 per color. The size of each 
sub-buffer is 3600 bytes, enough to hold 18- inches of single color dots at 1600 dpi. The 
memory is accessed 32-bits at a time, so there are 900 addresses for each buffer (requiring 
1 0 bits of address). 

All the even dots are placed before the odd dots in each color's buffer, as shown in Figure 
53. If there is any unused space it is placed at the end of each color's buffer. 



/ 

/ 

Buffer 0/1 



Figure 53. Conceptual Structure of Buffer 

The amount of memory actually used is directly related to the printhead length. If the print- 
head is 18 inches, there are 1800 bytes of even dots followed by 1800 bytes of odd dots, 
with no unused space. If the printhead is 12 inches, there are 1200 bytes of even dots fol- 
lowed by 1200 odd dots, and 1200 bytes unused. 

The number of sub-buffers gainfully used is directly related to the number of colors in the 
printhead. This number is typically 3 or 4, although it is quite feasible for this system to be 
used in a 1 or 2 color system (with some small memory wastage). In a desktop printing 
environment, the number of colors would be 4: Colorl=Cyan, Color2=Magenta, 
Color3=Yellow, Color4=Black. 

The addressing decoding circuitry is such that in a given cycle, a single 32-bit access can 
be made to all 4 sub-buffers - either a read from all 4 or a write to one of the 4. Only one 
bit of the 32-bits read from each color buffer is selected, for a total of 4 output bits. The 
process is shown in Figure 54. 15 bits of address allow the reading of a particular bit by 
means of 10-bits of address being used to select 32 bits, and 5-bits of address choose 1-bit 
from those 32. Since all color buffers share this logic, a single 15-bit address gives a total 
of 4 bits out, one per color. Each buffer has its own Write Enable line, to allow a single 
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32-bit value to be written to a particular color buffer in a given cycle. The 32-bits of 
Dataln are shared, since only one buffer will actually clock the data in. 
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Figure 54. Logical Structure of Buffer 

Note that regardless of the number of colors in the printhead, 4 bits are produced in a 
given read cycle (one bit from each color's buffer). 

15.4.2 Address Generation 

15.4.2.1 Reading 

Address Generation for reading is straightforward. Each cycle we generate a bit address 
which is used to fetch 4 bits representing 1-bit per color for a particular segment. By add- 
ing 400 to the current bit address, we advance to the next segment's equivalent dot. We 
add 400 (not 800) since the odd and even dots are separated in the buffer. We do this firstly 
SegmentGroups sets of SegmentsPerXfer times to retrieve the data representing the even 
dots (the dot data is transferred to the MJI 36 bits at a time) and another SegmentGroups 
sets of SegmentsPerXfer times to load the odd dots. This entire process is repeated 400 
times, incrementing the start address each time. Thus all dot values are transferred in the 
order required by the printhead in 400 x 2 x SegmentGroups x SegmentsPerXfer cycles. 

In addition, we generate the Transfer Write Enable control signal. Since the LLFU starts 
before the MJI, we must transfer the first value before the Advance pulse from the MJI. 
We must also generate the next value in readiness for the first Advance pulse. The solution 
is to transfer the first value to the Transfer register after SegmentsPerXfer cycles, and then 
to stall SegmentsPerXfer-cycles later, waiting for the Advance pulse to start the next Seg- 
mentsPerXfer cycle group. Once the first Advance pulse arrives, the LLFU is synchronized 
to the MJI. However, the LineSync pulse to start the next line must arrive at the MJI at 
least 2SegmentsPerXfer cycles after the LLFU so that the initial Transfer value is valid and 
the next 32-bit value is ready to be loaded into the Transfer register. 

The read process is shown in the following pseudocode: 
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DoneFirst = FALSE 

For DotlnSegmentO = 0 to 400 

CurrAdr = DotlnSegmentO 

Xf ersRemaining = 2 x SegmentGroups 

DotCount = SegmentsPerXf er 

Do 

VI = DotCount = 0 

TransferWriteEnable = (VI AND NOT DoneFirst} OR ADVANCE 
Stall = VI AND (NOT TransferWriteEnable) 
If (NOT Stall) 

Shift Regis ter=Fetch 4-bits from CurrReadBuff er : CurrAdr 
CurrAdr = CurrAdr + 4 00 
If (VI) 

DotCount = SegmentsPerXf er - 1 
Xf ersRemaining = Xf ersRemaining - 1 
Else 

DotCount = DotCount - 1 
Endlf 
Endlf 

Until (XfersRemaining=0) AND (NOT Stall) 

End For 



The final transfer may not be fully utilized. This occurs when the number of segments per 
transfer does not divide evenly into the actual number of segments in the printhead. An 
example of this is the 8 ! /4" printhead, which has 17 segments. Transferring 9 segments 
each time means that only 8 of the last 9 segments will be valid. Nonetheless, the timing 
requires the entire 9th segment value to be generated (even though it is not used). The 
actual address is therefore a don't care state since the data is not used. 

Once the line has finished, the CurrReadBuffer value must be toggled by the processor. 
15.4.2.2 Writing 

The write process is also straightforward. 4 DMA request lines are output to the DMA 
controller. As requests are satisfied by the return DMA Acknowledge lines, the appropri- 
ate 8-bit destination address is selected (the lower 5 bits of the 1 5-bit output address are 
don 't care values) and the acknowledge signal is passed to the correct buffer's WriteEnable 
control line (the Current Write Buffer is --CurrentRead Buffer). The 1 0-bit destination 
address is selected from the 4 current addresses, one address per color. As DMA requests 
are satisfied the appropriate destination address is incremented, and the corresponding 
TransfersRemaining counter is decremented. The DMA request line is only set when the 
number of transfers remaining for that color is non-zero. 

The following pseudocode illustrates the Write process: 



CurrentAdr [1-4] = 0 

While (ColorXf ersRemaining [ 1-4 ] are non-zero) 

DMARequest [ 1-4 ] = ColorXf ersRemaining [ 1 -4 ] NOT = 0 
If DMAAknowledge [N] 

CurrWri teBuf f er : CurrentAdr [N] - Fetch 32-bits from data bus 

CurrentAdr [N] = CurrentAdr [N] + 1 

ColorXf ersRemaining [N] = ColorXf ersRemaining [N] - 1 (floor 0) 
Endlf 
EndWhiie 
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15.4.3 Registers 

The following interface registers are contained in the LLFU: 



Table 21. Line Load/Format Unit Registers 



SegmentsPerXfer 



The number of segments whose dots must be loaded before 
each transfer. This has a maximum value of 9. 



SegmentG roups 


The number of segment groups in the printhead. This has a 
maximum number of 4. 


CurrentReadBuffer 


The current buffer being read from. When BufferO is being 

read from, Bufferl is written to and vice versa. 

Should be toggled with each AdvanceLine pulse from the 

MJI. 


Go 


Bits 0 and 1 control the starting of the read and write pro- 
cesses respectively. 

A non-zero write to the appropriate bit starts the process. 


Stop 


Bits 0 and 1 control the stopping of the read and write pro- 
cesses respectively. 

A non-zero write to the appropriate bit stops the process. 


Stall 


This read-only status bit comes from the LLFU's Stall flag. 
The Stall bit is valid when the write Go bit is set. 
A Stall value of 1 means that the LLFU ^ waiting for the 
ADVANCE pulse from the MJI to continue. The CPU can 
safely start the LSGU for the first line once the Stall bit is set. 


ColorXfersRemaining[1 -4] 


The number of 32-bit transfers remaining to be read into the 
specific Color(N] buffer. 



15.5 Controlling a Print 

When controlling a print the CPU programs and starts the LLFU in read mode to ensure 
that the first line of the page is transferred to the buffer. When the interrupts arrive from 
the DMA controller, the CPU can switch LLFU buffers, and program the MJI. The CPU 
then starts the LLFU in read/write mode and starts the MJI. The CPU should then wart a 
sufficient period of time to ensure that other connected printer controllers have also started 
their LLFUs and MJIs (if there are no other connected printer controllers, the CPU must 
wait until the Stall bit of the LLFU is set, a duration of 2SegmentsPerXfer cycles). The CPU 
can then program the LGSU to start the synchronized print. As interrupts arrive from the 
DMA controllers, the CPU can reprograrn the DMA channels, swap LLFU buffers, and 
restart the LLFU in read/write mode. Once the LLFU has effectively filled its pipeline, it 
will stall until the next Advance pulse from the MJI. The MJI does not have to be touched 
during the print. 

If for some reason the CPU wants to make any changes to the MJI or LLFU registers dur- 
ing an inter-line period it should ensure that the current line has finished printing/loading 
by polling the status bits of the MJI and the Go bits of the LLFU. 
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1 S-print Overview 

S-print is a high-speed duplex network color printer intended for high- volume office use. 
It features 2000-sheet motorized paper trays, 120 page-per-minute operation, and 1600 dpi 
photographic-quality output. 

With 20 times the speed of the best network color laser printers, and 4 times the speed of 
the best network monochrome laser printers, S-print effectively targets the $40 billion 
desktop laser printer market 1 . With its high performance and photographic-quality output, 
it also competes against offset printing for print runs smaller than 5000 copies. 

S-print accommodates A4/Letter sized media and, with a tray adapter, A3/Tabloid sized 
media. It achieves simultaneous high quality and performance using full-color page-width 
1600 dpi Memjet printheads. 

S-print uses an embedded DSP-based raster image processor (RIP) to rasterize Postscript 
and PCL page descriptions at high speed. The standard RIP uses a single DSP, but up to 
three additional DSP modules can be plugged in to increase performance. 

The RIP compresses and stores the rasterized page images on an internal high-capacity 
hard disk. While simple page descriptions are rasterized at the full 120 ppm printing rate, 
more complex page descriptions may take longer. Pre-rasterized documents retrieved 
from the internal hard disk are always printed at the full 120 ppm printing rate. Any docu- 
ment can be "printed" to the hard disk for later high-speed retrieval. 

Users can walk up to an S-print, select locally-stored documents on its color LCD, and 
print them immediately, without ever going near a workstation. Documents printed in this 
way always print at the full 120 ppm rate. The standard 14GB internal hard disk stores 
over 6000 image-intensive pages. Because of its walk-up capability and high speed, S- 
print is likely to displace many uses of short-run offset printing. 

S-print uses duplexed printheads for simultaneous double-sided printing. During the pilot 
phase of Memjet printhead manufacturing when the printhead defect density is still poten- 
tially high, each printhead is replicated to achieve 2:1 nozzle redundancy. This allows fac- 
tory-detected defective nozzles to be bypassed, and so maximises printhead yield. A pair 
of custom print engines expand, dither and print page images to the duplexed printheads in 
real time. 

Apart from custom print engines and Memjet printheads, S-print is built using standard 
off-the-shelf electronic components. 



1 . 1998 market size (source: [T Strategies) 
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2 Network Printer Comparison 

Table 1 compares the specifications and running costs of S-print with those of various 
Hewlett-Packard network laser printers, ranging from the entry-level HP 4500 to the high- 
end HP 8500, and including the high-end monochrome HP 8100. Product descriptions for 
these HP printers appear at the end of this document (from www.hp.com). 



Table 1. Network printer comparison 




Specifications 



Available 


Projected 2001 


Now 


Now 


Now 


Speed (color) 


120 ppm 


4 ppm 


6 ppm 


NA 


Speed (monochrome) 


1 20 ppm 


16 ppm 


24 ppm 


32 ppm 


Technology 


Liquid Inkjet 


Laser EP 


Laser EP 


Laser EP 


Dot pitch 


1600 dpi 


600 dpi 


600 dpi 


600 dpi 


Configuration 


Desktop 


Desktop 


Floor-standing 


Desktop 


Duty cycle (pages per month) 


600,000 


35,000 


60,000 


150,000 


Duplex 


Yes 


Option 


Option 


Option 


Full bleed (prints to edge of paper) 


Yes 


No 


No 


No 


Electronic collation 


Yes 


Option 


Option 


Option 


Walk-up printing of stored documents 


Yes 


No 


No 


Option 


Paper path 


Straight 


Complex 


Complex 


Complex 


Color mode! 


CMYK 


CMYK 


CMYK 


Monochrome 


Colorant 


Water-based ink 


Dry toner 


Dry toner 


Dry toner 


Network-ready 


Yes 


Option 


Option 


up lion 


Standard paper capacity 


2000 


400 


1100 


1100 


Optional maximum paper capacity 


2000 


900 


3100 


3100 


Maximum paper size 


A3/Tabioid 


aa/\ attar 


A3/Tabloid 


A3/Tabloid 


Raster image processor (RIP) 


1^ Parallel DSPs 


133 MHz MIPS 4700 


inn till- IJfDC A ~7 C\C\ 

133 MHZ Mlro 4/UU 


ififi MH? NIFP VR4310 


Memory (standard) 


64MB • 


32 MB. 


. 32 Md 


16 MB 


Memory (maximum) 


256 MB 


208 MB 


256 MB 


208 MB 


Disk drive 


14 GB 


Optional 2.1 GB 


Optional 2.1 GB 


Optional 2.1 GB 


Control panel 


Color TFT LCD 


2-line alpha LCD 


2-fine alpha LCD 


2-line alpha LCD 


Printer languages 


Postscript. PCL 


Postscript, PCL 


Postscript PCL 


Postscript PCL 


Fonts 


TrueType, Postscript 


TrueType, Postscript 


TrueType. Postscript 


TrueType. Postscript 


Warm-up time 


Instant 


5 minutes 


5 minutes 


1.5 minutes 


Power consumption (color) 


300 Watts 


300 Watts 


375 Watts 


NA 


Power consumption (monochrome) 


75 Watts 


500 Watts 


750 Watts 


700 Watts 


Power consumption (standby) 


2 Watts 


140 Watts 


220 Watts 


145 Watts 


Power consumption (15% coverage) 


40 Watts 


300 Watts 


300 Watts 


700 Watts 


Dimensions (H x W x D, imperial) 


13.4" x 20.5" X 14.6" 


15.4" x 19.7" x 22.4" 


41.7" X 26.3" X28.1" 


22.3" x 20.5" x 21.6" 


Dimensions (H x W x D, metric) 


340 x 520 x 370 mm 


390 x 500 x 570 mm 


1060 x 668 x 714 mm 


566 x 520 x 540 mm 


Weight 


20 kg (44 lb) 


50.8 kg (112 lb) 


101.2 kg (223 lb) 


54 kg (120 lb) 


Printer cost 










Minimum system 


$3,000 


$2,499 


$5,999 


$2,679 


Optioned system 6 


$6,000 


$4,674 


$7,895 


$5,774 


Consumables capacity 










Black inwtoner (5% coverage) 


88,778 pages 


9.000 pages 


17,000 pages 


20,000 pages 
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Table 1. Network printer comparison 




Color ink/toner (5% coverage) 
Drum kit 
Transfer kit 
Fuser kit 

Consumables cost 
Black ink/toner 
Color ink/toner 
Drum Kit 
Transfer kit 
Fuser kit 

Cost per page (not including paper) 

Light (5% coverage) 

Typical (15% coverage) 

Full page photos 

Annual consumables revenues 0 

Pages printed 

Revenue 



44,389 pages 
NA 
NA 
NA 

$100.00 
$150.00 
NA 
NA 
NA 

1.13 cents 
3.38 cents 
11.26 cents 

936,000 
$31,629 



6.000 pages 
6.500 pages 
25.000 pages 
50,000 pages 

$77.94 
$97.51 
$75.04 
$174.00 
$203.00 

8.00 cents 
1 9.48 cents 
59.67 cents 

31.200 
$6,078 



8.500 pages 
1 2.500 pages 
75.000 pages 
100,000 pages 

$136.00 
$190.00 
$187.00 
$445.00 
S360.00 

9.96 cents 
24.97 cents 
77.51 cents 

46,800 
$11,685 



NA 
NA 
NA 
NA 

$273.00 
NA 
NA 
NA 
NA 

1.37 cents 
4.10 cents 

13.65 cents 

249,600 
$10,221 



a. All HP specifications and prices from www.hp.com, 1 3 April 1 999. 

b. Duplex, network-ready, 2000-sheet capacity, 64MB, (S-print 4 DSPs). 

c. If the printer is used for 1 hour per day, 5 days per week, at 1 5% coverage, with 50% RIP overhead. 
High-end users will likely exceed his, while the average will probably be lower. 



The actual market in which S-print would compete is wider than the network color printer 
market, since Memjet-based printers can also undercut the cost-per-page of monochrome 
laser printers. 



In the table, the S-print ink is priced to slightly undercut monochrome laser printers, and 
to undercut color laser printers by a factor of 6 to 8. Color laser consumables are complex, 
including toner, complex mechanical toner stirring, imaging drums, transfer systems, fus- 
ers, and various other accessories. It is therefore doubtful that the price of these consum- 
ables could be reduced by a similar factor and still be profitable. 

S-print ink cartridges are highly profitable. The black ink cartridge contains 1 liter of ink, 
costs $5 to manufacture, and sells for $100. The color ink cartridge contains 0.5 liter of 
ink, costs $3.50 to manufacture, and sells for $150. 

The S-print printer is priced between $3000 and $6000 depending on options. This makes 
it competitive with high-end monochrome laser printers such as the HP 8 100. Just as color 
inkjet printers have displaced monochrome inkjet printers at the low end of the market, 
color is also likely to displace monochrome in the midrange once color matches or betters 
the speed and cost-per-page of monochrome. 

In the annual consumables section at the end of the table, S-print is shown to print almost 
four times as many pages as the HP 8100. This is enabled by the fact that it prints four 
times faster than the HP 8100, and is justified by the likelihood that it will displace much 
short-run offset-printing in favor of in-house printing. 
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3 Utilization of Pilot Phase 
Yield 

Printhead manufacturing volume is predicted to go through three major phases: 

/; An initial lab phase, where only around 100 wafers per month are processed, the 
yields are low to non-existent, and the available number of printheads is very lim- 
ited. Defect densities above 100 per cm 2 are assumed. 

2) A pilot phase, where the number of wafers processed each month is around 5000. 
Defect densities are assumed to be between 10 per cm 2 and 100 per cm 2 , necessitat- 
ing the use of redundancy to achieve good printhead yields. 

3) A full manufacturing phase, where 25,000 wafers are processed each month. Here 
defect densities are expected to fall from around 8 per cm 2 to u. 1 per cm 2 over the 
course of five years. During this phase, it is most cost-effective to not use printhead 
redundancy. 



s 

c 



o 




half inch fault tolerant 4 inch fault tolerant half inch sorted segments 4 inch sorted segments - - Optimum configuration 



Figure 1 . Millions of 8" printheads per quarter for various configurations 
(showing the optimum configuration) 

Figure l shows manufacturing volume as a function of printhead configuration. The pilot 
phase, from October 2000 to October 200 1 , is characterized by a manufacturing volume of 
about one million deployable 8" printheads, made possible by redundant-nozzle printhead 
configurations. The full manufacturing phase, starting in October 2001, is characterized 
by a rapidly increasing manufacturing volume no longer reliant on nozzle redundancy. 

The market focus during the pilot phase and the full manufacturing phase should be differ- 
ent. During the pilot phase, markets which are relatively insentitive to printhead cost 
should be targeted. These include: 

1) Wide-format printing (machine prices around $10,000) 

2) Network color printing (machine prices between $3000 and $7000) 
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3) Digital commercial printing (machine prices $ 1 00,000 and up) 

4) Photo finishing (machine prices between $5000 and $20,000) 

During the full manufacturing phase, high volume markets can also be targeted. 

One million redundantly-deployable 8" printheads is sufficient for around 167,000 S-print 
printers. 

Table 2 indicates the size of the various digital printing markets. Markets in which S-print 
is likely to compete effectively are highlit. 

Table 2. Selected digital printing markets, 1998 (source: IT Strategies) 




Consumer & SOHO Ink Jet 
F^ax/MFP * 
Cotor Copier 
Wide Format Graphic 
Wide Format CAD 
Bar Code/Direct Mail/Coding 



$17,800 M 


$9,000 M 


$3,520 M 


$5,280 M 


29.000.000 


81.000.000 


$8,000 M 


$4,000 M 


$1,500 M 


$2,500 M 


5.000,000 


12.500.000 


$5,750 M 


$2,000 M 


* $750 M 


$3,000 M 


45,000 


183,000 


$2,930 M 


S500 M 


$1,080 M 


$1,350 M 


44.000 


84,000 


$1,733 M 


$450 M 


$513 M 


$770 M 


125.000 


500,000 


$1,150 M 


$750 M 


$100 M 


$300 M 


14,000 


75,000 




Kiosk Photo Printing 


$241 M 


$120 M 


$48 M 


$73 M 


10,000 


36.000 


Card Printing (ID. Smart Cards) 


$300 M 


$101 M 


$109 M 


$90 M 


18,000 


51.000 


Proofing Printing 


$513 M 


$250 M 


$105 M 


$158 M 


11.000 


72.000 


MICR Printing 


$205 M 


$90 M 


$50 M 


$65 M 


15,000 


50.000 


Medical Printing (X-ray. diagnostic) 


$125 M 


$35 M 


$50 M 


$40 M 


3.000 


15.000 


Forms Printing 


$110 M 


S50 M 


$20 M 


$40 M 


500 


1,500 


Label Printing 


$13 M 


$10 M 


$2M 


$1 M 


15,000 


16.000 


Total 


$82,520 M 


$34,251 M 


$18,777 M 


$29,492 M 


42,820,500 


134,083,500 



S-print competes at the high end of this market, where the unit price of a printer is above $2000. 
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4 Printer Mechanics 

S-print is compact, with minimum dimensions of 13.4 n (340 mm) high by 20.5" (521 mm) 
wide by 14.6" (371 mm) deep (see Figure 2). As the print engine is small, the machine is 
dominated by paper and ink storage. 




14.6" (371 mm) 



Figure 2. Plan and elevations of S-print printer unit 
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Figure 3. Front elevation of S -print (rotated) 

The overall views of S-print are shown in Figure 3 and Figure 4. The elevation in Figure 3 
shows the basic structure of the printer, [t is built around a steel box section chassis with 
metal front, back and base panels attached. Two motorized paper trays form the basic 
paper path, with the imaging engines in the middle. The printer prints the wide edge of the 
paper to enable A3/Tabloid printing, and to achieve a compact form factor. 
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Figure 4. Plan of S-print 
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-j-^dded, color-tinted, transparent housing with a hinged door and 

the ii!ol° t0r P ° WerS Paper P ick ' u P rolIer which feeds the sheet through to 

tl^ t 8 T? nCS L^ C tOP m ° Iding in FigUre 5 can be «d hinged upZt o 

and p,voted upward for access to the printheads and drying lamps. u™cKed 
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Figure 5. Ink supply and paper path between duplexed imaging engines 
Figure 5 shows the workings of S-print. The straight paper path allows the paper to be fed 
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S^h^^ WhiCh - b — • - of spfce wheels 



Confidential 



22 May 1999 



9 



Sitverbrook Research 



S-print Product Concept 



draft vO. 2 



The ink cartridges snap fit onto the top molding. Ink is automatically fed via a sprung col- 
lared pin into a permanent ink reservoir. The reservoir serves to provide an early warning 
to replace the ink cartridge and makes the contact with the embedded QA cartridge chip. 
The provision of a large reservoir means that the ink cartridges typically only need to be 
replaced when all four colors are empty, rather than when the first color is empty. Each 
ink color reservoir connects via hoses to the printhead extrusion assemblies, which are 
daisy chained together via flexible hose connections (Figure 4). 

The main PCB, power supply and 14GB hard disk are shown in Figure 3. Access to these 
components is via the front and rear moldings. 





H 0 # O $ 

e o f f f 




Figure 6. Front panel user interface 

Figure 6 shows the color LCD interface with four changeable function buttons for navigat- 
ing the user interface. The LCD displays a preview of the front page of the document to be 
printed. The keypad on the front molding allows the desired number of copies to be 
entered. Documents to be printed locally can also be selected by an ID number using the 
keypad. This can be quicker than scrolling through stored documents if there are many. 
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4.1 Imaging Engines 

S-print uses duplexed imaging engines (Figure 7) for simultaneous double-sided printing. 
During the pilot phase of manufacturing when the printhead defect density is still poten- 
tially high, each printhead is replicated to achieve 2:1 nozzle redundancy. This allows fac- 
tory-detected defective nozzles to be bypassed, and so maximises printhead yield. 




metal 
eectlon 



Figure 7. Duplexed imaging engines and drying lamps 

Each imaging engine therefore contains two printhead assemblies (Figure 8) mounted 
side-by-side, sharing the same powered transfer roller and cleaning station. 

The four printhead assemblies in the two imaging engines share the same ink supply. 
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Filter Frlnthead chip 




Extrusion Ink Bus bars 



Figure 8. Cross-section of printhead assembly 
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5 Ink Cartridge 

The black cartridge holds 1 liter (33.8 fluid ounces 1 ), while the cyan, magenta and yellow 
cartridges each hold half a liter. The cartridges plug directly into the top of the printer and 
are comprised of two main moldings ultrasonically welded together with a QA chip in the 
lower molding (Figure 9). 

The upper molding houses a sprung ball-bearing that is held captive against the inner 
molding. This provides the main seal to the cartridge with a secondary hydrophobic elas- 
tomeric seal to the entry port on the lower molding. 



Label 




Figure 9. Ink cartridge explosion 

The cartridge connects to the printheads via the printer ink reservoir. This has a hollow pin 
that emerges from a sprung sleeve when the cartridge is pushed on. The pin pushes the ball 
bearing back and allows ink to flow. Tortuous hydrophobic air channels are provided at 
the top of the unit under the label. The four ink cartridges are differently keyed by plastic 
protrusions to prevent any incorrect insertion or orientation of the units. 



1. 2.1 I US pints, 1.76 British pints, or 0.0042 hogsheads. 
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6 Memjet-Based Printing 

A Memjet printhead produces 1600 dpi bi-leve! CMYK. On low-diffusion paper, each 
ejected drop forms an almost perfectly circular 22.5um diameter dot Dots are easily pro- 
duced in isolation, allowing dispersed-dot dithering to be exploited to its fullest. Since the 
Memjet printhead is the width of the page and operates with a constant paper velocity, the 
four color planes are printed in perfect registration, allowing ideal dot-on-dot printing. 
Since there is consequently no spatial interaction between color planes, the same dither 
matrix is used for each color plane. Dot-on-dot printing minimizes 'muddying' of mid- 
tones caused by inter-color bleed. 

A page layout may contain a mixture of images, graphics and text. Continuous-tone (con- 
tone) images and graphics are reproduced using a stochastic dispersed-dot dither. Unlike a 
clustered-dot (or amplitude-modulated) dither, a dispersed-dot (or frequency-modulated) 
dither reproduces high spatial frequencies (i.e. image detail) almost to the limits of the dot 
resolution, while simultaneously reproducing lower spatial frequencies to their full color 
depth, when spatially integrated by the eye. A stochastic dither matrix is carefully 
designed to be free of objectionable low-frequency patterns when tiled across the image. 
As such its size typically exceeds the minimum size required to support a particular num- 
ber of intensity levels (e.g. 16x16x8 bits for 257 intensity levels). S-print uses a dither vol- 
ume of size 64x64x3x8 bits. The volume provides an extra degree of freedom during the 
design of the dither by allowing a dot to change states multiple times through the intensity 
range (rather than just once as in a conventional dither matrix). 

Human contrast sensitivity peaks at a spatial frequency of about 3 cycles per degree of 
visual field and then falls off logarithmically, decreasing by a factor of 100 beyond about 
40 cycles per degree and becoming immeasurable beyond 60 cycles per degree. At a nor- 
mal viewing distance of 12 inches (about 300mm), this translates roughly to 200-300 
cycles per inch (cpi) on the printed page, or 400-600 samples per inch according to 
Nyquist's theorem. 

In practice, contone resolution above about 300 ppi is of limited utility outside special 
applications, such as medical imaging. Offset printing of magazines, for example, uses 
contone resolutions in the range 150 to 3'00 ppi. Higher resolutions contribute slightly to 
color error through the dither. 

Black text and graphics are reproduced directly using bi-level black dots, and are therefore 
not antialiased (i.e. low-pass filtered) before being printed. Text is therefore supersampled 
beyond the perceptual limits discussed above, to produce smoother edges when spatially 
integrated by the eye. Text resolution up to about 1200 dpi continues to contribute to per- 
ceived text sharpness (assuming low-diffusion paper, of course). 

S-print uses a contone resolution of 320 ppi (i.e. 1600-^5), and a black text and graphics 
resolution of 1600 dpi. 
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7 Document Data Flow 



Document transmission and document rasterization are decoupled to shield the user from 
interactions between the size and complexity of the document, and the memory capacity 
and RIP performance of S-print. This is achieved by storing each document's PDL file on 
the internal hard disk. 

Because of the high resolution of the Memjet printhead, each page must be printed at a 
constant speed to avoid creating visible artifacts. This means that the printing speed can't 
be varied to match the input data rate. Document rasterization and document printing are 
therefore decoupled to ensure the printhead has a constant supply of data. A page is never 
printed until it is fully rasterized. This is achieved by storing a compressed version of each 
rasterized page image on the internal hard disk. 

This decoupling also allows the RIP to run ahead of the printer when rasterizing simple 
pages, buying time to rasterize more complex pages. 

The user indicates whether a document is to be stored permanently on the hard disk, 
printed, or both. So long as there is disk space available, the pages of transient documents 
are also cached on the disk until printed. This is particularly efficient when multiple copies 
of complex documents are being printed. This so-called electronic collation also obviates 
the need for an external collating mechanism, since each copy of a document is printed in 
its entirety before the next copy. 

Because contone color images are reproduced by stochastic dithering, but black text and 
line graphics are reproduced directly using black dots, the compressed page image format 
contains a separate foreground bi-ievel black layer and background contone color layer. 
The black layer is composited over the contone layer after the contone layer is dithered. 

Figure 1 0 shows the flow of a S-print document from network to printed page. 



Poscript or PCL 
page descriptions 




Figure 10. S-print document data flow 
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At 320 ppi, an Abetter page 1 of contone CMYK data has a size of 38MB. Using lossy 
contone compression algorithms such as JPEQ contone images compress with a ratio up 
to 10: 1 without noticeable loss of quality, giving a compressed page size of 3.8MB. 

At 1600 dpi, an A4/Letter page of bi-level data has a size of 30MB. Coherent data such as 
text compresses very well. Using lossless bi-level compression algorithms such as Group 
4 Facsimile, ten-point text compresses with a ratio of about 20:1, giving a compressed 
page size of 1.5MB. 

Once dithered, a page of CMYK contone image data consists of 120MB of bi-level data. 
Using lossless bi-level compression algorithms on this data is pointless precisely because 
the optimal dither is stochastic - i.e. since it introduces hard-to-cqmpress disorder. 

The two-layer compressed page image format therefore exploits the relative strengths of 
lossy JPEG contone image compression and lossless bi-level text compression. The for- 
mat is compact enough to be storage-efficient, and simple enough to allow straightforward 
realtime expansion during printing. 

Since text and images normally don't overlap, the normal worst-case page image size is 
3.8MB (i.e. image-only), while the normal best-case page image size is 1.5MB (i.e. text- 
only). The absolute worst-case page image size is 5.3MB (i.e. text over image). Assuming 
a third of an average page contains images, the average page image size is 2.3MB. The 
standard 14GB internal hard disk therefore holds over 6000 such pages. 



I . An A4/Letter page has a maximum area of 8.3"X 1 1 .7" (i.e. A4). 
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8 Printer Controller 
Architecture 

The S-print printer controller consists of a controlling processor, various peripheral con- 
trollers, a raster image processor (RIP) DSP farm, and duplexed print engines. These com- 
ponents are discrete and communicate via a shared bus and a shared 64MB memory, as 
illustrated in Figure 11. 




Figure 11. Printer controller architecture 

The controlling processor handles communication with the network, controls the internal 
hard disk, controls the user interface (LCD, buttons and LEDs), controls the paper trans- 
port, handles ink cartridge authentication and ink monitoring, and feeds and synchronizes 
the RIP and the print engines. It consists of a medium -performance general-purpose 
microprocessor. Its associated peripheral controllers include a 10/lOOBase-T Ethernet 
controller, a SCSI disk controller, and a color TFT LCD controller. Optional controllers 
include an IEEE 1 394 (Firewire) controller and a USB 2.0 controller for high-speed point- 
to-point communication with a workstation or server. 

The RIP DSP farm rasterizes and compresses page descriptions to S-print's compressed 
page format. The DSP farm consists of between one and four general-purpose high-perfor- 
mance DSPs. Each additional DSP comes as a field-installable plug-in module. 



Each print engine expands, dithers and prints page images to its associated replicated 
printhead in real time (i.e. at 60 ppm). The duplexed print engines print both sides of the 
page simultaneously (i.e. at 1 20 ppm). 
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The printer controller's flash memory holds the software for both the processor and the 
DSPs. This is copied to main memory at boot time. The flash memory also holds the 
defect characterization vectors for the two replicated printheads. These are copied to the 
print engines at boot time. 

8,1 Detailed Document Data Flow 

The main processor receives the document's PDL file and stores it on the internal hard 
disk. It then runs the appropriate RIP software on the DSPs. 

The DSPs rasterize each page description and compress the rasterized page image. The 
main processor stores each compressed page image on the hard disk. The simplest way to 
load-balance multiple DSPs is to let each DSP rasterize a separate page. The DSPs can 
always be kept busy since an arbitrary number of rasterized pages can, in general, be 
stored on the internal hard disk. This strategy can lead to poor DSP utilization, however, 
when rasterizing short documents. 

The main processor passes back-to-back page images to the duplexed print engines. Each 
print engine stores the compressed page image into its local memory, and starts the page 
expansion and printing pipeline. Page expansion and printing is pipelined because it is 
impractical to store a 120MB bi-level CMYK image in memory. 

The first stage of the pipeline expands the JPEG-compressed contone CMYK layer. The 
second stage, in parallel with the first, expands the Group 4 Fax-compressed bi-level black 
layer. The third stage dithers the contone CMYK layer, and composites the bi-level black 
layer over the resulting bi-level CMYK layer. The fourth stage prints the bi-level CMYK 
data via the printhead interface which controls the Memjet printhead. 

The main processor streams compressed page images from the hard disk to the print 
engines at the required 120 ppm rate (i.e. 4.6MB/s on average, or 10.6MB/s worst-case). 



Table 3. Print engine page image and FIFO data flow 
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a. dither combines with composite, so there is no external data flow between them 

b. 320 ppi => 1600 dpi (5x5 expansion). 
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c. Needs a window of 24 lines, but only advances 1 tine. 

The print engine data flow is summarized in Table 3. The aggregate traffic to/from mem- 
ory is 387MB/S, all but 5.3MB/S of which relates to the FIFOs. 

Each stage communicates with the next via a FIFO. Each FIFO is organized into lines, and 
the minimum size (in lines) of each FIFO is designed to accommodate the output window 
(in lines) of the producer and the input window (in lines) of the consumer. The inter-stage 
memory FIFOs are described in Table 4. 

Table 4. Print engine local memory FIFOs 
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8.2 Print Engine Architecture 



The print engine is implemented as a single custom chip. It shares a common design with 
print engines used in other Memjet printers. 



print engine 
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Figure 1 2. Shared-memory print engine architecture 

There are two architectural variants of the print engine. The shared-memory version uses a 
local off-chip RDRAM to support the aggregate memory bandwidth required by page 
expansion and printing (see Figure 12). The pipelined version uses dedicated on-chip 
FIFOs (see Figure 13). 
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The shared-memory print engine consists of a general-purpose processor, a high-speed 
Rambus interface to the off-chip RDRAM, a small program ROM, a DMA controller, and 
an interface to the printer controller bus. 

Both print engine's page expansion and printing pipeline consists of a standard JPEG 
decoder, a standard Group 4 Fax decoder, a custom ditherer/compositor unit, and a custom 
interface to the Memjet printheads. These are described in detail in design documents. 

In the shared-memory version, the FIFOs are located in the dedicated off-chip RDRAM, 
and all inter-stage communication is controlled by the local processor via DMA. In the 
pipelined version, the FIFOs are on-chip, and the stages are self-synchronizing. 

In the shared-memory version, the decoders obtain page data from the main processor via 
the local memory. In the pipelined version, the decoders obtain page data directly from the 
main processor over the printer controller bus. 




Figure 13. Pipelined print engine architecture 

When several print engines are used in unison, such as in a duplexed configuration, they 
are synchronized via a shared line sync signal. Only one print engine, selected via the 
external master/slave pin, generates the line sync signal onto the shared line. 
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8.3 



Printhead Timing 



Each print engine prints an A4/Letter page in one second. Since S-print uses a 12" print- 
head to print the long dimension of the page (11.7"), the printhead needs to traverse die 
short dimension of the page (8.5") in one second. At 1600 dpi, this equates to a 13.6KHz 
line rate. This is well within the operating frequency of the Memjet printhead, which in the 
current design exceeds 30KHz. 



Each redundant 12" printhead contains two complete 12" printheads, i.e. 76,800 nozzle 
pairs, characterized and matched so that no paired nozzles are both defective. 

Printhead defects are either characterized and matched one segment at a time, or after the 
entire printhead has been built. In the former case nozzles are tested before integration 
with the ink path, and so are tested without ink. In the latter case nozzles are tested after 
integration with the ink path, and so are tested with ink. Segment-wise characterization 
gives a higher yield, but at a higher testing cost. It is therefore only preferable to print- 
head- wise characterization when defect densities are still high. 

A characterization vector indicates, via one bit per nozzle pair, which nozzle of the pair is 
to be used. A 12" printhead characterization vector requires 9600 bytes to represent. 

Once determined, the characterization vector associated with a redundant printhead is 
stored in the manufacturing database, indexed by the printhead's serial number, recorded 
as a barcode on its cartridge. When the printhead cartridge is finally inserted into a printer 
during manufacture, the characterization vector is retrieved using the barcode, and is writ- 
ten to the flash memory of the printer's embedded printer controller. 

If the printhead cartridge is replaced in the field, then a new characterization vector is 
downloaded remotely from the manufacturing database to the printer controller via its net- 
work interface, using the new printhead cartridge's barcode. 



8.4 



Printhead Characterization 
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